@libp2p/mplex 7.1.0 → 7.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +15 -159
- package/dist/index.min.js +25 -0
- package/dist/typedoc-urls.json +4 -0
- package/package.json +4 -3
package/README.md
CHANGED
@@ -1,30 +1,18 @@
|
|
1
1
|
# @libp2p/mplex <!-- omit in toc -->
|
2
2
|
|
3
3
|
[](http://libp2p.io/)
|
4
|
-
[](http://webchat.freenode.net/?channels=%23libp2p)
|
5
4
|
[](https://discuss.libp2p.io)
|
6
5
|
[](https://codecov.io/gh/libp2p/js-libp2p-mplex)
|
7
|
-
[](https://github.com/libp2p/js-libp2p-mplex/actions/workflows/js-test-and-release.yml?query=branch%3Amaster)
|
8
7
|
|
9
8
|
> JavaScript implementation of <https://github.com/libp2p/mplex>
|
10
9
|
|
11
10
|
## Table of contents <!-- omit in toc -->
|
12
11
|
|
13
12
|
- [Install](#install)
|
13
|
+
- [Browser `<script>` tag](#browser-script-tag)
|
14
14
|
- [Usage](#usage)
|
15
|
-
- [API](#api)
|
16
|
-
- [`const factory = new Mplex([options])`](#const-factory--new-mplexoptions)
|
17
|
-
- [`const muxer = factory.createStreamMuxer(components, [options])`](#const-muxer--factorycreatestreammuxercomponents-options)
|
18
|
-
- [`muxer.onStream`](#muxeronstream)
|
19
|
-
- [`muxer.onStreamEnd`](#muxeronstreamend)
|
20
|
-
- [`muxer.streams`](#muxerstreams)
|
21
|
-
- [`const stream = muxer.newStream([options])`](#const-stream--muxernewstreamoptions)
|
22
|
-
- [`stream.close()`](#streamclose)
|
23
|
-
- [`stream.abort([err])`](#streamaborterr)
|
24
|
-
- [`stream.reset()`](#streamreset)
|
25
|
-
- [`stream.timeline`](#streamtimeline)
|
26
|
-
- [`stream.id`](#streamid)
|
27
|
-
- [Contribute](#contribute)
|
15
|
+
- [API Docs](#api-docs)
|
28
16
|
- [License](#license)
|
29
17
|
- [Contribution](#contribution)
|
30
18
|
|
@@ -34,15 +22,23 @@
|
|
34
22
|
$ npm i @libp2p/mplex
|
35
23
|
```
|
36
24
|
|
25
|
+
### Browser `<script>` tag
|
26
|
+
|
27
|
+
Loading this module through a script tag will make it's exports available as `Libp2pMplex` in the global namespace.
|
28
|
+
|
29
|
+
```html
|
30
|
+
<script src="https://unpkg.com/@libp2p/mplex/dist/index.min.js"></script>
|
31
|
+
```
|
32
|
+
|
37
33
|
[](https://github.com/libp2p/interface-stream-muxer)
|
38
34
|
|
39
35
|
## Usage
|
40
36
|
|
41
37
|
```js
|
42
|
-
import {
|
38
|
+
import { mplex } from '@libp2p/mplex'
|
43
39
|
import { pipe } from 'it-pipe'
|
44
40
|
|
45
|
-
const factory =
|
41
|
+
const factory = mplex()
|
46
42
|
|
47
43
|
const muxer = factory.createStreamMuxer(components, {
|
48
44
|
onStream: stream => { // Receive a duplex stream from the remote
|
@@ -61,149 +57,9 @@ const stream = muxer.newStream() // Create a new duplex stream to the remote
|
|
61
57
|
pipe([1, 2, 3], stream)
|
62
58
|
```
|
63
59
|
|
64
|
-
## API
|
65
|
-
|
66
|
-
### `const factory = new Mplex([options])`
|
67
|
-
|
68
|
-
Creates a factory that can be used to create new muxers.
|
69
|
-
|
70
|
-
`options` is an optional `Object` that may have the following properties:
|
71
|
-
|
72
|
-
- `maxMsgSize` - a number that defines how large mplex data messages can be in bytes, if messages are larger than this they will be sent as multiple messages (default: 1048576 - e.g. 1MB)
|
73
|
-
- `maxUnprocessedMessageQueueSize` - a number that limits the size of the unprocessed input buffer (default: 4194304 - e.g. 4MB)
|
74
|
-
- `minSendBytes` - if set, message bytes from the current tick will be batched up to this amount before being yielded by the muxer source, unless the next tick begins in which case all available bytes will be yielded
|
75
|
-
- `maxInboundStreams` - a number that defines how many incoming streams are allowed per connection (default: 1024)
|
76
|
-
- `maxOutboundStreams` - a number that defines how many outgoing streams are allowed per connection (default: 1024)
|
77
|
-
- `maxStreamBufferSize` - a number that defines how large the message buffer is allowed to grow (default: 1024 \* 1024 \* 4 - e.g. 4MB)
|
78
|
-
- `disconnectThreshold` - if `maxInboundStreams` is reached, close the connection if the remote continues trying to open more than this many streams per second (default: 5)
|
79
|
-
|
80
|
-
### `const muxer = factory.createStreamMuxer(components, [options])`
|
81
|
-
|
82
|
-
Create a new *duplex* stream that can be piped together with a connection in order to allow multiplexed communications.
|
83
|
-
|
84
|
-
e.g.
|
85
|
-
|
86
|
-
```js
|
87
|
-
import { Mplex } from '@libp2p/mplex'
|
88
|
-
import { pipe } from 'it-pipe'
|
89
|
-
|
90
|
-
// Create a duplex muxer
|
91
|
-
const muxer = new Mplex()
|
92
|
-
|
93
|
-
// Use the muxer in a pipeline
|
94
|
-
pipe(conn, muxer, conn) // conn is duplex connection to another peer
|
95
|
-
```
|
96
|
-
|
97
|
-
`options` is an optional `Object` that may have the following properties:
|
98
|
-
|
99
|
-
- `onStream` - A function called when receiving a new stream from the remote. e.g.
|
100
|
-
```js
|
101
|
-
// Receive a new stream on the muxed connection
|
102
|
-
const onStream = stream => {
|
103
|
-
// Read from this stream and write back to it (echo server)
|
104
|
-
pipe(
|
105
|
-
stream,
|
106
|
-
source => (async function * () {
|
107
|
-
for await (const data of source) yield data
|
108
|
-
})(),
|
109
|
-
stream
|
110
|
-
)
|
111
|
-
}
|
112
|
-
const muxer = new Mplex({ onStream })
|
113
|
-
// ...
|
114
|
-
```
|
115
|
-
**Note:** The `onStream` function can be passed in place of the `options` object. i.e.
|
116
|
-
```js
|
117
|
-
new Mplex(stream => { /* ... */ })
|
118
|
-
```
|
119
|
-
- `onStreamEnd` - A function called when a stream ends
|
120
|
-
```js
|
121
|
-
// Receive a notification when a stream ends
|
122
|
-
const onStreamEnd = stream => {
|
123
|
-
// Manage any tracking changes, etc
|
124
|
-
}
|
125
|
-
const muxer = new Mplex({ onStreamEnd })
|
126
|
-
// ...
|
127
|
-
```
|
128
|
-
- `signal` - An [`AbortSignal`](https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal) which can be used to abort the muxer, *including* all of it's multiplexed connections. e.g.
|
129
|
-
```js
|
130
|
-
const controller = new AbortController()
|
131
|
-
const muxer = new Mplex({ signal: controller.signal })
|
132
|
-
|
133
|
-
pipe(conn, muxer, conn)
|
134
|
-
|
135
|
-
controller.abort()
|
136
|
-
```
|
137
|
-
- `maxMsgSize` - The maximum size in bytes the data field of multiplexed messages may contain (default 1MB)
|
138
|
-
|
139
|
-
### `muxer.onStream`
|
140
|
-
|
141
|
-
Use this property as an alternative to passing `onStream` as an option to the `Mplex` constructor.
|
142
|
-
|
143
|
-
### `muxer.onStreamEnd`
|
144
|
-
|
145
|
-
Use this property as an alternative to passing `onStreamEnd` as an option to the `Mplex` constructor.
|
146
|
-
|
147
|
-
### `muxer.streams`
|
148
|
-
|
149
|
-
Returns an `Array` of streams that are currently open. Closed streams will not be returned.
|
150
|
-
|
151
|
-
### `const stream = muxer.newStream([options])`
|
152
|
-
|
153
|
-
Initiate a new stream with the remote. Returns a [duplex stream](https://gist.github.com/alanshaw/591dc7dd54e4f99338a347ef568d6ee9#duplex-it).
|
154
|
-
|
155
|
-
e.g.
|
156
|
-
|
157
|
-
```js
|
158
|
-
// Create a new stream on the muxed connection
|
159
|
-
const stream = muxer.newStream()
|
160
|
-
|
161
|
-
// Use this new stream like any other duplex stream:
|
162
|
-
pipe([1, 2, 3], stream, consume)
|
163
|
-
```
|
164
|
-
|
165
|
-
In addition to `sink` and `source` properties, this stream also has the following API, that will **normally *not* be used by stream consumers**.
|
166
|
-
|
167
|
-
#### `stream.close()`
|
168
|
-
|
169
|
-
Closes the stream for **reading**. If iterating over the source of this stream in a `for await of` loop, it will return (exit the loop) after any buffered data has been consumed.
|
170
|
-
|
171
|
-
This function is called automatically by the muxer when it receives a `CLOSE` message from the remote.
|
172
|
-
|
173
|
-
The source will return normally, the sink will continue to consume.
|
174
|
-
|
175
|
-
#### `stream.abort([err])`
|
176
|
-
|
177
|
-
Closes the stream for **reading** *and* **writing**. This should be called when a *local error* has occurred.
|
178
|
-
|
179
|
-
Note, if called without an error any buffered data in the source can still be consumed and the stream will end normally.
|
180
|
-
|
181
|
-
This will cause a `RESET` message to be sent to the remote, *unless* the sink has already ended.
|
182
|
-
|
183
|
-
The sink will return and the source will throw if an error is passed or return normally if not.
|
184
|
-
|
185
|
-
#### `stream.reset()`
|
186
|
-
|
187
|
-
Closes the stream *immediately* for **reading** *and* **writing**. This should be called when a *remote error* has occurred.
|
188
|
-
|
189
|
-
This function is called automatically by the muxer when it receives a `RESET` message from the remote.
|
190
|
-
|
191
|
-
The sink will return and the source will throw.
|
192
|
-
|
193
|
-
#### `stream.timeline`
|
194
|
-
|
195
|
-
Returns an `object` with `close` and `open` times of the stream.
|
196
|
-
|
197
|
-
#### `stream.id`
|
198
|
-
|
199
|
-
Returns a `string` with an identifier unique to **this** muxer. Identifiers are not unique across muxers.
|
200
|
-
|
201
|
-
## Contribute
|
202
|
-
|
203
|
-
The libp2p implementation in JavaScript is a work in progress. As such, there are a few things you can do right now to help out:
|
60
|
+
## API Docs
|
204
61
|
|
205
|
-
-
|
206
|
-
- **Perform code reviews**. More eyes will help a) speed the project along b) ensure quality and c) reduce possible future bugs.
|
62
|
+
- <https://libp2p.github.io/js-libp2p-mplex>
|
207
63
|
|
208
64
|
## License
|
209
65
|
|
@@ -0,0 +1,25 @@
|
|
1
|
+
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PMplex = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
2
|
+
"use strict";var Libp2PMplex=(()=>{var Ti=Object.create;var be=Object.defineProperty;var Li=Object.getOwnPropertyDescriptor;var Ii=Object.getOwnPropertyNames;var Mi=Object.getPrototypeOf,Ni=Object.prototype.hasOwnProperty;var g=(i,e)=>()=>(e||i((e={exports:{}}).exports,e),e.exports),M=(i,e)=>{for(var t in e)be(i,t,{get:e[t],enumerable:!0})},Lt=(i,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Ii(e))!Ni.call(i,n)&&n!==t&&be(i,n,{get:()=>e[n],enumerable:!(r=Li(e,n))||r.enumerable});return i};var K=(i,e,t)=>(t=i!=null?Ti(Mi(i)):{},Lt(e||!i||!i.__esModule?be(t,"default",{value:i,enumerable:!0}):t,i)),ki=i=>Lt(be({},"__esModule",{value:!0}),i);var Bt=g((wo,vt)=>{vt.exports=Ne;var Pt=128,Pi=127,vi=~Pi,Bi=Math.pow(2,31);function Ne(i,e,t){if(Number.MAX_SAFE_INTEGER&&i>Number.MAX_SAFE_INTEGER)throw Ne.bytes=0,new RangeError("Could not encode varint");e=e||[],t=t||0;for(var r=t;i>=Bi;)e[t++]=i&255|Pt,i/=128;for(;i&vi;)e[t++]=i&255|Pt,i>>>=7;return e[t]=i|0,Ne.bytes=t-r+1,e}});var Ft=g((go,Dt)=>{Dt.exports=ke;var Oi=128,Ot=127;function ke(i,r){var t=0,r=r||0,n=0,s=r,o,a=i.length;do{if(s>=a||n>49)throw ke.bytes=0,new RangeError("Could not decode varint");o=i[s++],t+=n<28?(o&Ot)<<n:(o&Ot)*Math.pow(2,n),n+=7}while(o>=Oi);return ke.bytes=s-r,t}});var qt=g((Eo,Ut)=>{var Di=Math.pow(2,7),Fi=Math.pow(2,14),Ui=Math.pow(2,21),qi=Math.pow(2,28),$i=Math.pow(2,35),zi=Math.pow(2,42),Vi=Math.pow(2,49),Ki=Math.pow(2,56),Wi=Math.pow(2,63);Ut.exports=function(i){return i<Di?1:i<Fi?2:i<Ui?3:i<qi?4:i<$i?5:i<zi?6:i<Vi?7:i<Ki?8:i<Wi?9:10}});var zt=g((_o,$t)=>{$t.exports={encode:Bt(),decode:Ft(),encodingLength:qt()}});var Ue=g((jo,Zt)=>{"use strict";function Jt(i,e){for(let t in e)Object.defineProperty(i,t,{value:e[t],enumerable:!0,configurable:!0});return i}function Qi(i,e,t){if(!i||typeof i=="string")throw new TypeError("Please pass an Error to err-code");t||(t={}),typeof e=="object"&&(t=e,e=""),e&&(t.code=e);try{return Jt(i,t)}catch{t.message=i.message,t.stack=i.stack;let n=function(){};return n.prototype=Object.create(Object.getPrototypeOf(i)),Jt(new n,t)}}Zt.exports=Qi});var $e=g((Ho,qe)=>{function er(i){let e=new globalThis.AbortController;function t(){e.abort();for(let r of i)!r||!r.removeEventListener||r.removeEventListener("abort",t)}for(let r of i)if(!(!r||!r.addEventListener)){if(r.aborted){t();break}r.addEventListener("abort",t)}return e.signal}qe.exports=er;qe.exports.anySignal=er});var xr=g((Oa,_r)=>{var ee=1e3,te=ee*60,re=te*60,G=re*24,os=G*7,as=G*365.25;_r.exports=function(i,e){e=e||{};var t=typeof i;if(t==="string"&&i.length>0)return cs(i);if(t==="number"&&isFinite(i))return e.long?ls(i):us(i);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(i))};function cs(i){if(i=String(i),!(i.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(e){var t=parseFloat(e[1]),r=(e[2]||"ms").toLowerCase();switch(r){case"years":case"year":case"yrs":case"yr":case"y":return t*as;case"weeks":case"week":case"w":return t*os;case"days":case"day":case"d":return t*G;case"hours":case"hour":case"hrs":case"hr":case"h":return t*re;case"minutes":case"minute":case"mins":case"min":case"m":return t*te;case"seconds":case"second":case"secs":case"sec":case"s":return t*ee;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function us(i){var e=Math.abs(i);return e>=G?Math.round(i/G)+"d":e>=re?Math.round(i/re)+"h":e>=te?Math.round(i/te)+"m":e>=ee?Math.round(i/ee)+"s":i+"ms"}function ls(i){var e=Math.abs(i);return e>=G?Re(i,e,G,"day"):e>=re?Re(i,e,re,"hour"):e>=te?Re(i,e,te,"minute"):e>=ee?Re(i,e,ee,"second"):i+" ms"}function Re(i,e,t,r){var n=e>=t*1.5;return Math.round(i/t)+" "+r+(n?"s":"")}});var Cr=g((Da,Sr)=>{function hs(i){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=n,t.enabled=o,t.humanize=xr(),t.destroy=l,Object.keys(i).forEach(u=>{t[u]=i[u]}),t.names=[],t.skips=[],t.formatters={};function e(u){let h=0;for(let d=0;d<u.length;d++)h=(h<<5)-h+u.charCodeAt(d),h|=0;return t.colors[Math.abs(h)%t.colors.length]}t.selectColor=e;function t(u){let h,d=null,E,m;function f(...b){if(!f.enabled)return;let x=f,R=Number(new Date),A=R-(h||R);x.diff=A,x.prev=h,x.curr=R,h=R,b[0]=t.coerce(b[0]),typeof b[0]!="string"&&b.unshift("%O");let _=0;b[0]=b[0].replace(/%([a-zA-Z%])/g,(y,p)=>{if(y==="%%")return"%";_++;let I=t.formatters[p];if(typeof I=="function"){let j=b[_];y=I.call(x,j),b.splice(_,1),_--}return y}),t.formatArgs.call(x,b),(x.log||t.log).apply(x,b)}return f.namespace=u,f.useColors=t.useColors(),f.color=t.selectColor(u),f.extend=r,f.destroy=t.destroy,Object.defineProperty(f,"enabled",{enumerable:!0,configurable:!1,get:()=>d!==null?d:(E!==t.namespaces&&(E=t.namespaces,m=t.enabled(u)),m),set:b=>{d=b}}),typeof t.init=="function"&&t.init(f),f}function r(u,h){let d=t(this.namespace+(typeof h>"u"?":":h)+u);return d.log=this.log,d}function n(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let h,d=(typeof u=="string"?u:"").split(/[\s,]+/),E=d.length;for(h=0;h<E;h++)d[h]&&(u=d[h].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function s(){let u=[...t.names.map(a),...t.skips.map(a).map(h=>"-"+h)].join(",");return t.enable(""),u}function o(u){if(u[u.length-1]==="*")return!0;let h,d;for(h=0,d=t.skips.length;h<d;h++)if(t.skips[h].test(u))return!1;for(h=0,d=t.names.length;h<d;h++)if(t.names[h].test(u))return!0;return!1}function a(u){return u.toString().substring(2,u.toString().length-2).replace(/\.\*\?$/,"*")}function c(u){return u instanceof Error?u.stack||u.message:u}function l(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.enable(t.load()),t}Sr.exports=hs});var Rr=g((N,Ae)=>{N.formatArgs=ds;N.save=ms;N.load=ps;N.useColors=fs;N.storage=bs();N.destroy=(()=>{let i=!1;return()=>{i||(i=!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`."))}})();N.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"];function fs(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function ds(i){if(i[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+i[0]+(this.useColors?"%c ":" ")+"+"+Ae.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;i.splice(1,0,e,"color: inherit");let t=0,r=0;i[0].replace(/%[a-zA-Z%]/g,n=>{n!=="%%"&&(t++,n==="%c"&&(r=t))}),i.splice(r,0,e)}N.log=console.debug||console.log||(()=>{});function ms(i){try{i?N.storage.setItem("debug",i):N.storage.removeItem("debug")}catch{}}function ps(){let i;try{i=N.storage.getItem("debug")}catch{}return!i&&typeof process<"u"&&"env"in process&&(i=process.env.DEBUG),i}function bs(){try{return localStorage}catch{}}Ae.exports=Cr()(N);var{formatters:ys}=Ae.exports;ys.j=function(i){try{return JSON.stringify(i)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var me=g((fc,Lr)=>{Lr.exports=class{constructor(e={}){this.points=e.points,this.duration=e.duration,this.blockDuration=e.blockDuration,this.execEvenly=e.execEvenly,this.execEvenlyMinDelayMs=e.execEvenlyMinDelayMs,this.keyPrefix=e.keyPrefix}get points(){return this._points}set points(e){this._points=e>=0?e:4}get duration(){return this._duration}set duration(e){this._duration=typeof e>"u"?1:e}get msDuration(){return this.duration*1e3}get blockDuration(){return this._blockDuration}set blockDuration(e){this._blockDuration=typeof e>"u"?0:e}get msBlockDuration(){return this.blockDuration*1e3}get execEvenly(){return this._execEvenly}set execEvenly(e){this._execEvenly=typeof e>"u"?!1:Boolean(e)}get execEvenlyMinDelayMs(){return this._execEvenlyMinDelayMs}set execEvenlyMinDelayMs(e){this._execEvenlyMinDelayMs=typeof e>"u"?Math.ceil(this.msDuration/this.points):e}get keyPrefix(){return this._keyPrefix}set keyPrefix(e){if(typeof e>"u"&&(e="rlflx"),typeof e!="string")throw new Error("keyPrefix must be string");this._keyPrefix=e}_getKeySecDuration(e={}){return e&&e.customDuration>=0?e.customDuration:this.duration}getKey(e){return this.keyPrefix.length>0?`${this.keyPrefix}:${e}`:e}parseKey(e){return e.substring(this.keyPrefix.length)}consume(){throw new Error("You have to implement the method 'consume'!")}penalty(){throw new Error("You have to implement the method 'penalty'!")}reward(){throw new Error("You have to implement the method 'reward'!")}get(){throw new Error("You have to implement the method 'get'!")}set(){throw new Error("You have to implement the method 'set'!")}block(){throw new Error("You have to implement the method 'block'!")}delete(){throw new Error("You have to implement the method 'delete'!")}}});var Mr=g((mc,Ir)=>{Ir.exports=class{constructor(){this._keys={},this._addedKeysAmount=0}collectExpired(){let e=Date.now();Object.keys(this._keys).forEach(t=>{this._keys[t]<=e&&delete this._keys[t]}),this._addedKeysAmount=Object.keys(this._keys).length}add(e,t){this.addMs(e,t*1e3)}addMs(e,t){this._keys[e]=Date.now()+t,this._addedKeysAmount++,this._addedKeysAmount>999&&this.collectExpired()}msBeforeExpire(e){let t=this._keys[e];if(t&&t>=Date.now()){this.collectExpired();let r=Date.now();return t>=r?t-r:0}return 0}delete(e){e?delete this._keys[e]:Object.keys(this._keys).forEach(t=>{delete this._keys[t]})}}});var kr=g((pc,Nr)=>{var _s=Mr();Nr.exports=_s});var k=g((yc,Pr)=>{Pr.exports=class{constructor(e,t,r,n){this.remainingPoints=typeof e>"u"?0:e,this.msBeforeNext=typeof t>"u"?0:t,this.consumedPoints=typeof r>"u"?0:r,this.isFirstInDuration=typeof n>"u"?!1:n}get msBeforeNext(){return this._msBeforeNext}set msBeforeNext(e){return this._msBeforeNext=e,this}get remainingPoints(){return this._remainingPoints}set remainingPoints(e){return this._remainingPoints=e,this}get consumedPoints(){return this._consumedPoints}set consumedPoints(e){return this._consumedPoints=e,this}get isFirstInDuration(){return this._isFirstInDuration}set isFirstInDuration(e){this._isFirstInDuration=Boolean(e)}_getDecoratedProperties(){return{remainingPoints:this.remainingPoints,msBeforeNext:this.msBeforeNext,consumedPoints:this.consumedPoints,isFirstInDuration:this.isFirstInDuration}}[Symbol.for("nodejs.util.inspect.custom")](){return this._getDecoratedProperties()}toString(){return JSON.stringify(this._getDecoratedProperties())}toJSON(){return this._getDecoratedProperties()}}});var ie=g((gc,Br)=>{var dt=me(),xs=kr(),vr=k();Br.exports=class extends dt{constructor(e={}){super(e),this.inMemoryBlockOnConsumed=e.inMemoryBlockOnConsumed||e.inmemoryBlockOnConsumed,this.inMemoryBlockDuration=e.inMemoryBlockDuration||e.inmemoryBlockDuration,this.insuranceLimiter=e.insuranceLimiter,this._inMemoryBlockedKeys=new xs}get client(){return this._client}set client(e){if(typeof e>"u")throw new Error("storeClient is not set");this._client=e}_afterConsume(e,t,r,n,s,o={}){let a=this._getRateLimiterRes(r,n,s);if(this.inMemoryBlockOnConsumed>0&&!(this.inMemoryBlockDuration>0)&&a.consumedPoints>=this.inMemoryBlockOnConsumed)return this._inMemoryBlockedKeys.addMs(r,a.msBeforeNext),a.consumedPoints>this.points?t(a):e(a);if(a.consumedPoints>this.points){let c=Promise.resolve();this.blockDuration>0&&a.consumedPoints<=this.points+n&&(a.msBeforeNext=this.msBlockDuration,c=this._block(r,a.consumedPoints,this.msBlockDuration,o)),this.inMemoryBlockOnConsumed>0&&a.consumedPoints>=this.inMemoryBlockOnConsumed&&(this._inMemoryBlockedKeys.add(r,this.inMemoryBlockDuration),a.msBeforeNext=this.msInMemoryBlockDuration),c.then(()=>{t(a)}).catch(l=>{t(l)})}else if(this.execEvenly&&a.msBeforeNext>0&&!a.isFirstInDuration){let c=Math.ceil(a.msBeforeNext/(a.remainingPoints+2));c<this.execEvenlyMinDelayMs&&(c=a.consumedPoints*this.execEvenlyMinDelayMs),setTimeout(e,c,a)}else e(a)}_handleError(e,t,r,n,s,o=!1,a={}){this.insuranceLimiter instanceof dt?this.insuranceLimiter[t](s,o,a).then(c=>{r(c)}).catch(c=>{n(c)}):n(e)}get _inmemoryBlockedKeys(){return this._inMemoryBlockedKeys}getInmemoryBlockMsBeforeExpire(e){return this.getInMemoryBlockMsBeforeExpire(e)}get inmemoryBlockOnConsumed(){return this.inMemoryBlockOnConsumed}set inmemoryBlockOnConsumed(e){this.inMemoryBlockOnConsumed=e}get inmemoryBlockDuration(){return this.inMemoryBlockDuration}set inmemoryBlockDuration(e){this.inMemoryBlockDuration=e}get msInmemoryBlockDuration(){return this.inMemoryBlockDuration*1e3}getInMemoryBlockMsBeforeExpire(e){return this.inMemoryBlockOnConsumed>0?this._inMemoryBlockedKeys.msBeforeExpire(e):0}get inMemoryBlockOnConsumed(){return this._inMemoryBlockOnConsumed}set inMemoryBlockOnConsumed(e){if(this._inMemoryBlockOnConsumed=e?parseInt(e):0,this.inMemoryBlockOnConsumed>0&&this.points>this.inMemoryBlockOnConsumed)throw new Error('inMemoryBlockOnConsumed option must be greater or equal "points" option')}get inMemoryBlockDuration(){return this._inMemoryBlockDuration}set inMemoryBlockDuration(e){if(this._inMemoryBlockDuration=e?parseInt(e):0,this.inMemoryBlockDuration>0&&this.inMemoryBlockOnConsumed===0)throw new Error("inMemoryBlockOnConsumed option must be set up")}get msInMemoryBlockDuration(){return this._inMemoryBlockDuration*1e3}get insuranceLimiter(){return this._insuranceLimiter}set insuranceLimiter(e){if(typeof e<"u"&&!(e instanceof dt))throw new Error("insuranceLimiter must be instance of RateLimiterAbstract");this._insuranceLimiter=e,this._insuranceLimiter&&(this._insuranceLimiter.blockDuration=this.blockDuration,this._insuranceLimiter.execEvenly=this.execEvenly)}block(e,t,r={}){let n=t*1e3;return this._block(this.getKey(e),this.points+1,n,r)}set(e,t,r,n={}){let s=(r>=0?r:this.duration)*1e3;return this._block(this.getKey(e),t,s,n)}consume(e,t=1,r={}){return new Promise((n,s)=>{let o=this.getKey(e),a=this.getInMemoryBlockMsBeforeExpire(o);if(a>0)return s(new vr(0,a));this._upsert(o,t,this._getKeySecDuration(r)*1e3,!1,r).then(c=>{this._afterConsume(n,s,o,t,c)}).catch(c=>{this._handleError(c,"consume",n,s,e,t,r)})})}penalty(e,t=1,r={}){let n=this.getKey(e);return new Promise((s,o)=>{this._upsert(n,t,this._getKeySecDuration(r)*1e3,!1,r).then(a=>{s(this._getRateLimiterRes(n,t,a))}).catch(a=>{this._handleError(a,"penalty",s,o,e,t,r)})})}reward(e,t=1,r={}){let n=this.getKey(e);return new Promise((s,o)=>{this._upsert(n,-t,this._getKeySecDuration(r)*1e3,!1,r).then(a=>{s(this._getRateLimiterRes(n,-t,a))}).catch(a=>{this._handleError(a,"reward",s,o,e,t,r)})})}get(e,t={}){let r=this.getKey(e);return new Promise((n,s)=>{this._get(r,t).then(o=>{n(o===null||typeof o>"u"?null:this._getRateLimiterRes(r,0,o))}).catch(o=>{this._handleError(o,"get",n,s,e,t)})})}delete(e,t={}){let r=this.getKey(e);return new Promise((n,s)=>{this._delete(r,t).then(o=>{this._inMemoryBlockedKeys.delete(r),n(o)}).catch(o=>{this._handleError(o,"delete",n,s,e,t)})})}deleteInMemoryBlockedAll(){this._inMemoryBlockedKeys.delete()}_getRateLimiterRes(e,t,r){throw new Error("You have to implement the method '_getRateLimiterRes'!")}_block(e,t,r,n={}){return new Promise((s,o)=>{this._upsert(e,t,r,!0,n).then(()=>{s(new vr(0,r>0?r:-1,t))}).catch(a=>{this._handleError(a,"block",s,o,this.parseKey(e),r/1e3,n)})})}_get(e,t={}){throw new Error("You have to implement the method '_get'!")}_delete(e,t={}){throw new Error("You have to implement the method '_delete'!")}_upsert(e,t,r,n=!1,s={}){throw new Error("You have to implement the method '_upsert'!")}}});var Fr=g((Ec,Dr)=>{var Ss=ie(),Cs=k(),Or="redis.call('set', KEYS[1], 0, 'EX', ARGV[2], 'NX') local consumed = redis.call('incrby', KEYS[1], ARGV[1]) local ttl = redis.call('pttl', KEYS[1]) if ttl == -1 then redis.call('expire', KEYS[1], ARGV[2]) ttl = 1000 * ARGV[2] end return {consumed, ttl} ",mt=class extends Ss{constructor(e){super(e),e.redis?this.client=e.redis:this.client=e.storeClient,this._rejectIfRedisNotReady=!!e.rejectIfRedisNotReady,typeof this.client.defineCommand=="function"&&this.client.defineCommand("rlflxIncr",{numberOfKeys:1,lua:Or})}_isRedisReady(){return this._rejectIfRedisNotReady?!(this.client.status&&this.client.status!=="ready"||typeof this.client.isReady=="function"&&!this.client.isReady()):!0}_getRateLimiterRes(e,t,r){let[n,s]=r;Array.isArray(n)&&([,n]=n,[,s]=s);let o=new Cs;return o.consumedPoints=parseInt(n),o.isFirstInDuration=o.consumedPoints===t,o.remainingPoints=Math.max(this.points-o.consumedPoints,0),o.msBeforeNext=s,o}_upsert(e,t,r,n=!1){return new Promise((s,o)=>{if(!this._isRedisReady())return o(new Error("Redis connection is not ready"));let a=Math.floor(r/1e3),c=this.client.multi();if(n)a>0?c.set(e,t,"EX",a):c.set(e,t),c.pttl(e).exec((l,u)=>l?o(l):s(u));else if(a>0){let l=function(u,h){return u?o(u):s(h)};typeof this.client.rlflxIncr=="function"?this.client.rlflxIncr(e,t,a,l):this.client.eval(Or,1,e,t,a,l)}else c.incrby(e,t).pttl(e).exec((l,u)=>l?o(l):s(u))})}_get(e){return new Promise((t,r)=>{if(!this._isRedisReady())return r(new Error("Redis connection is not ready"));this.client.multi().get(e).pttl(e).exec((n,s)=>{if(n)r(n);else{let[o]=s;if(o===null)return t(null);t(s)}})})}_delete(e){return new Promise((t,r)=>{this.client.del(e,(n,s)=>{n?r(n):t(s>0)})})}};Dr.exports=mt});var $r=g((_c,qr)=>{var Rs=ie(),As=k();function Ur(i){try{let e=i.client?i.client:i,{version:t}=e.topology.s.options.metadata.driver,r=t.split(".").map(n=>parseInt(n));return{major:r[0],feature:r[1],patch:r[2]}}catch{return{major:0,feature:0,patch:0}}}var pe=class extends Rs{constructor(e){super(e),this.dbName=e.dbName,this.tableName=e.tableName,this.indexKeyPrefix=e.indexKeyPrefix,e.mongo?this.client=e.mongo:this.client=e.storeClient,typeof this.client.then=="function"?this.client.then(t=>{this.client=t,this._initCollection(),this._driverVersion=Ur(this.client)}):(this._initCollection(),this._driverVersion=Ur(this.client))}get dbName(){return this._dbName}set dbName(e){this._dbName=typeof e>"u"?pe.getDbName():e}static getDbName(){return"node-rate-limiter-flexible"}get tableName(){return this._tableName}set tableName(e){this._tableName=typeof e>"u"?this.keyPrefix:e}get client(){return this._client}set client(e){if(typeof e>"u")throw new Error("mongo is not set");this._client=e}get indexKeyPrefix(){return this._indexKeyPrefix}set indexKeyPrefix(e){this._indexKeyPrefix=e||{}}_initCollection(){let t=(typeof this.client.db=="function"?this.client.db(this.dbName):this.client).collection(this.tableName);t.createIndex({expire:-1},{expireAfterSeconds:0}),t.createIndex(Object.assign({},this.indexKeyPrefix,{key:1}),{unique:!0}),this._collection=t}_getRateLimiterRes(e,t,r){let n=new As,s;return typeof r.value>"u"?s=r:s=r.value,n.isFirstInDuration=s.points===t,n.consumedPoints=s.points,n.remainingPoints=Math.max(this.points-n.consumedPoints,0),n.msBeforeNext=s.expire!==null?Math.max(new Date(s.expire).getTime()-Date.now(),0):-1,n}_upsert(e,t,r,n=!1,s={}){if(!this._collection)return Promise.reject(Error("Mongo connection is not established"));let o=s.attrs||{},a,c;n?(a={key:e},a=Object.assign(a,o),c={$set:{key:e,points:t,expire:r>0?new Date(Date.now()+r):null}},c.$set=Object.assign(c.$set,o)):(a={$or:[{expire:{$gt:new Date}},{expire:{$eq:null}}],key:e},a=Object.assign(a,o),c={$setOnInsert:{key:e,expire:r>0?new Date(Date.now()+r):null},$inc:{points:t}},c.$setOnInsert=Object.assign(c.$setOnInsert,o));let l={upsert:!0};return this._driverVersion.major>=4||this._driverVersion.major===3&&this._driverVersion.feature>=7||this._driverVersion.feature>=6&&this._driverVersion.patch>=7?l.returnDocument="after":l.returnOriginal=!1,new Promise((u,h)=>{this._collection.findOneAndUpdate(a,c,l).then(d=>{u(d)}).catch(d=>{if(d&&d.code===11e3){let E=Object.assign({$or:[{expire:{$lte:new Date}},{expire:{$eq:null}}],key:e},o),m={$set:Object.assign({key:e,points:t,expire:r>0?new Date(Date.now()+r):null},o)};this._collection.findOneAndUpdate(E,m,l).then(f=>{u(f)}).catch(f=>{f&&f.code===11e3?this._upsert(e,t,r,n).then(b=>u(b)).catch(b=>h(b)):h(f)})}else h(d)})})}_get(e,t={}){if(!this._collection)return Promise.reject(Error("Mongo connection is not established"));let r=t.attrs||{},n=Object.assign({key:e,$or:[{expire:{$gt:new Date}},{expire:{$eq:null}}]},r);return this._collection.findOne(n)}_delete(e,t={}){if(!this._collection)return Promise.reject(Error("Mongo connection is not established"));let r=t.attrs||{},n=Object.assign({key:e},r);return this._collection.deleteOne(n).then(s=>s.deletedCount>0)}};qr.exports=pe});var Vr=g((xc,zr)=>{var Ts=ie(),Ls=k(),pt=class extends Ts{constructor(e,t=null){super(e),this.client=e.storeClient,this.clientType=e.storeType,this.dbName=e.dbName,this.tableName=e.tableName,this.clearExpiredByTimeout=e.clearExpiredByTimeout,this.tableCreated=e.tableCreated,this.tableCreated?(this.clearExpiredByTimeout&&this._clearExpiredHourAgo(),typeof t=="function"&&t()):this._createDbAndTable().then(()=>{this.tableCreated=!0,this.clearExpiredByTimeout&&this._clearExpiredHourAgo(),typeof t=="function"&&t()}).catch(r=>{if(typeof t=="function")t(r);else throw r})}clearExpired(e){return new Promise(t=>{this._getConnection().then(r=>{r.query("DELETE FROM ??.?? WHERE expire < ?",[this.dbName,this.tableName,e],()=>{this._releaseConnection(r),t()})}).catch(()=>{t()})})}_clearExpiredHourAgo(){this._clearExpiredTimeoutId&&clearTimeout(this._clearExpiredTimeoutId),this._clearExpiredTimeoutId=setTimeout(()=>{this.clearExpired(Date.now()-36e5).then(()=>{this._clearExpiredHourAgo()})},3e5),this._clearExpiredTimeoutId.unref()}_getConnection(){switch(this.clientType){case"pool":return new Promise((e,t)=>{this.client.getConnection((r,n)=>{if(r)return t(r);e(n)})});case"sequelize":return this.client.connectionManager.getConnection();case"knex":return this.client.client.acquireConnection();default:return Promise.resolve(this.client)}}_releaseConnection(e){switch(this.clientType){case"pool":return e.release();case"sequelize":return this.client.connectionManager.releaseConnection(e);case"knex":return this.client.client.releaseConnection(e);default:return!0}}_createDbAndTable(){return new Promise((e,t)=>{this._getConnection().then(r=>{r.query(`CREATE DATABASE IF NOT EXISTS \`${this.dbName}\`;`,n=>{if(n)return this._releaseConnection(r),t(n);r.query(this._getCreateTableStmt(),s=>{if(s)return this._releaseConnection(r),t(s);this._releaseConnection(r),e()})})}).catch(r=>{t(r)})})}_getCreateTableStmt(){return`CREATE TABLE IF NOT EXISTS \`${this.dbName}\`.\`${this.tableName}\` (\`key\` VARCHAR(255) CHARACTER SET utf8 NOT NULL,\`points\` INT(9) NOT NULL default 0,\`expire\` BIGINT UNSIGNED,PRIMARY KEY (\`key\`)) ENGINE = INNODB;`}get clientType(){return this._clientType}set clientType(e){if(typeof e>"u")if(this.client.constructor.name==="Connection")e="connection";else if(this.client.constructor.name==="Pool")e="pool";else if(this.client.constructor.name==="Sequelize")e="sequelize";else throw new Error("storeType is not defined");this._clientType=e.toLowerCase()}get dbName(){return this._dbName}set dbName(e){this._dbName=typeof e>"u"?"rtlmtrflx":e}get tableName(){return this._tableName}set tableName(e){this._tableName=typeof e>"u"?this.keyPrefix:e}get tableCreated(){return this._tableCreated}set tableCreated(e){this._tableCreated=typeof e>"u"?!1:!!e}get clearExpiredByTimeout(){return this._clearExpiredByTimeout}set clearExpiredByTimeout(e){this._clearExpiredByTimeout=typeof e>"u"?!0:Boolean(e)}_getRateLimiterRes(e,t,r){let n=new Ls,[s]=r;return n.isFirstInDuration=t===s.points,n.consumedPoints=n.isFirstInDuration?t:s.points,n.remainingPoints=Math.max(this.points-n.consumedPoints,0),n.msBeforeNext=s.expire?Math.max(s.expire-Date.now(),0):-1,n}_upsertTransaction(e,t,r,n,s){return new Promise((o,a)=>{e.query("BEGIN",c=>{if(c)return e.rollback(),a(c);let l=Date.now(),u=n>0?l+n:null,h,d;s?(h=`INSERT INTO ??.?? VALUES (?, ?, ?)
|
3
|
+
ON DUPLICATE KEY UPDATE
|
4
|
+
points = ?,
|
5
|
+
expire = ?;`,d=[this.dbName,this.tableName,t,r,u,r,u]):(h=`INSERT INTO ??.?? VALUES (?, ?, ?)
|
6
|
+
ON DUPLICATE KEY UPDATE
|
7
|
+
points = IF(expire <= ?, ?, points + (?)),
|
8
|
+
expire = IF(expire <= ?, ?, expire);`,d=[this.dbName,this.tableName,t,r,u,l,r,r,l,u]),e.query(h,d,E=>{if(E)return e.rollback(),a(E);e.query("SELECT points, expire FROM ??.?? WHERE `key` = ?;",[this.dbName,this.tableName,t],(m,f)=>{if(m)return e.rollback(),a(m);e.query("COMMIT",b=>{if(b)return e.rollback(),a(b);o(f)})})})})})}_upsert(e,t,r,n=!1){return this.tableCreated?new Promise((s,o)=>{this._getConnection().then(a=>{this._upsertTransaction(a,e,t,r,n).then(c=>{s(c),this._releaseConnection(a)}).catch(c=>{o(c),this._releaseConnection(a)})}).catch(a=>{o(a)})}):Promise.reject(Error("Table is not created yet"))}_get(e){return this.tableCreated?new Promise((t,r)=>{this._getConnection().then(n=>{n.query("SELECT points, expire FROM ??.?? WHERE `key` = ? AND (`expire` > ? OR `expire` IS NULL)",[this.dbName,this.tableName,e,Date.now()],(s,o)=>{s?r(s):o.length===0?t(null):t(o),this._releaseConnection(n)})}).catch(n=>{r(n)})}):Promise.reject(Error("Table is not created yet"))}_delete(e){return this.tableCreated?new Promise((t,r)=>{this._getConnection().then(n=>{n.query("DELETE FROM ??.?? WHERE `key` = ?",[this.dbName,this.tableName,e],(s,o)=>{s?r(s):t(o.affectedRows>0),this._releaseConnection(n)})}).catch(n=>{r(n)})}):Promise.reject(Error("Table is not created yet"))}};zr.exports=pt});var Wr=g((Sc,Kr)=>{var Is=ie(),Ms=k(),bt=class extends Is{constructor(e,t=null){super(e),this.client=e.storeClient,this.clientType=e.storeType,this.tableName=e.tableName,this.clearExpiredByTimeout=e.clearExpiredByTimeout,this.tableCreated=e.tableCreated,this.tableCreated?typeof t=="function"&&t():this._createTable().then(()=>{this.tableCreated=!0,this.clearExpiredByTimeout&&this._clearExpiredHourAgo(),typeof t=="function"&&t()}).catch(r=>{if(typeof t=="function")t(r);else throw r})}clearExpired(e){return new Promise(t=>{let r={name:"rlflx-clear-expired",text:`DELETE FROM ${this.tableName} WHERE expire < $1`,values:[e]};this._query(r).then(()=>{t()}).catch(()=>{t()})})}_clearExpiredHourAgo(){this._clearExpiredTimeoutId&&clearTimeout(this._clearExpiredTimeoutId),this._clearExpiredTimeoutId=setTimeout(()=>{this.clearExpired(Date.now()-36e5).then(()=>{this._clearExpiredHourAgo()})},3e5),this._clearExpiredTimeoutId.unref()}_getConnection(){switch(this.clientType){case"pool":return Promise.resolve(this.client);case"sequelize":return this.client.connectionManager.getConnection();case"knex":return this.client.client.acquireConnection();case"typeorm":return Promise.resolve(this.client.driver.master);default:return Promise.resolve(this.client)}}_releaseConnection(e){switch(this.clientType){case"pool":return!0;case"sequelize":return this.client.connectionManager.releaseConnection(e);case"knex":return this.client.client.releaseConnection(e);case"typeorm":return!0;default:return!0}}_createTable(){return new Promise((e,t)=>{this._query({text:this._getCreateTableStmt()}).then(()=>{e()}).catch(r=>{r.code==="23505"?e():t(r)})})}_getCreateTableStmt(){return`CREATE TABLE IF NOT EXISTS ${this.tableName} (
|
9
|
+
key varchar(255) PRIMARY KEY,
|
10
|
+
points integer NOT NULL DEFAULT 0,
|
11
|
+
expire bigint
|
12
|
+
);`}get clientType(){return this._clientType}set clientType(e){let t=this.client.constructor.name;if(typeof e>"u")if(t==="Client")e="client";else if(t==="Pool"||t==="BoundPool")e="pool";else if(t==="Sequelize")e="sequelize";else throw new Error("storeType is not defined");this._clientType=e.toLowerCase()}get tableName(){return this._tableName}set tableName(e){this._tableName=typeof e>"u"?this.keyPrefix:e}get tableCreated(){return this._tableCreated}set tableCreated(e){this._tableCreated=typeof e>"u"?!1:!!e}get clearExpiredByTimeout(){return this._clearExpiredByTimeout}set clearExpiredByTimeout(e){this._clearExpiredByTimeout=typeof e>"u"?!0:Boolean(e)}_getRateLimiterRes(e,t,r){let n=new Ms,s=r.rows[0];return n.isFirstInDuration=t===s.points,n.consumedPoints=n.isFirstInDuration?t:s.points,n.remainingPoints=Math.max(this.points-n.consumedPoints,0),n.msBeforeNext=s.expire?Math.max(s.expire-Date.now(),0):-1,n}_query(e){let r={name:`${this.tableName.toLowerCase()}:${e.name}`,text:e.text,values:e.values};return new Promise((n,s)=>{this._getConnection().then(o=>{o.query(r).then(a=>{n(a),this._releaseConnection(o)}).catch(a=>{s(a),this._releaseConnection(o)})}).catch(o=>{s(o)})})}_upsert(e,t,r,n=!1){if(!this.tableCreated)return Promise.reject(Error("Table is not created yet"));let s=r>0?Date.now()+r:null,o=n?" $3 ":` CASE
|
13
|
+
WHEN ${this.tableName}.expire <= $4 THEN $3
|
14
|
+
ELSE ${this.tableName}.expire
|
15
|
+
END `;return this._query({name:n?"rlflx-upsert-force":"rlflx-upsert",text:`
|
16
|
+
INSERT INTO ${this.tableName} VALUES ($1, $2, $3)
|
17
|
+
ON CONFLICT(key) DO UPDATE SET
|
18
|
+
points = CASE
|
19
|
+
WHEN (${this.tableName}.expire <= $4 OR 1=${n?1:0}) THEN $2
|
20
|
+
ELSE ${this.tableName}.points + ($2)
|
21
|
+
END,
|
22
|
+
expire = ${o}
|
23
|
+
RETURNING points, expire;`,values:[e,t,s,Date.now()]})}_get(e){return this.tableCreated?new Promise((t,r)=>{this._query({name:"rlflx-get",text:`
|
24
|
+
SELECT points, expire FROM ${this.tableName} WHERE key = $1 AND (expire > $2 OR expire IS NULL);`,values:[e,Date.now()]}).then(n=>{n.rowCount===0&&(n=null),t(n)}).catch(n=>{r(n)})}):Promise.reject(Error("Table is not created yet"))}_delete(e){return this.tableCreated?this._query({name:"rlflx-delete",text:`DELETE FROM ${this.tableName} WHERE key = $1`,values:[e]}).then(t=>t.rowCount>0):Promise.reject(Error("Table is not created yet"))}};Kr.exports=bt});var Gr=g(()=>{});var jr=g(()=>{});var Yr=g((Ic,Hr)=>{Hr.exports=class{constructor(e,t,r=null){this.value=e,this.expiresAt=t,this.timeoutId=r}get value(){return this._value}set value(e){this._value=parseInt(e)}get expiresAt(){return this._expiresAt}set expiresAt(e){!(e instanceof Date)&&Number.isInteger(e)&&(e=new Date(e)),this._expiresAt=e}get timeoutId(){return this._timeoutId}set timeoutId(e){this._timeoutId=e}}});var Xr=g((Nc,Qr)=>{var Ns=Yr(),yt=k();Qr.exports=class{constructor(){this._storage={}}incrby(e,t,r){if(this._storage[e]){let n=this._storage[e].expiresAt?this._storage[e].expiresAt.getTime()-new Date().getTime():-1;return n!==0?(this._storage[e].value=this._storage[e].value+t,new yt(0,n,this._storage[e].value,!1)):this.set(e,t,r)}return this.set(e,t,r)}set(e,t,r){let n=r*1e3;return this._storage[e]&&this._storage[e].timeoutId&&clearTimeout(this._storage[e].timeoutId),this._storage[e]=new Ns(t,n>0?new Date(Date.now()+n):null),n>0&&(this._storage[e].timeoutId=setTimeout(()=>{delete this._storage[e]},n),this._storage[e].timeoutId.unref&&this._storage[e].timeoutId.unref()),new yt(0,n===0?-1:n,this._storage[e].value,!0)}get(e){if(this._storage[e]){let t=this._storage[e].expiresAt?this._storage[e].expiresAt.getTime()-new Date().getTime():-1;return new yt(0,t,this._storage[e].value,!1)}return null}delete(e){return this._storage[e]?(this._storage[e].timeoutId&&clearTimeout(this._storage[e].timeoutId),delete this._storage[e],!0):!1}}});var gt=g((kc,Zr)=>{var ks=me(),Ps=Xr(),Jr=k(),wt=class extends ks{constructor(e={}){super(e),this._memoryStorage=new Ps}consume(e,t=1,r={}){return new Promise((n,s)=>{let o=this.getKey(e),a=this._getKeySecDuration(r),c=this._memoryStorage.incrby(o,t,a);if(c.remainingPoints=Math.max(this.points-c.consumedPoints,0),c.consumedPoints>this.points)this.blockDuration>0&&c.consumedPoints<=this.points+t&&(c=this._memoryStorage.set(o,c.consumedPoints,this.blockDuration)),s(c);else if(this.execEvenly&&c.msBeforeNext>0&&!c.isFirstInDuration){let l=Math.ceil(c.msBeforeNext/(c.remainingPoints+2));l<this.execEvenlyMinDelayMs&&(l=c.consumedPoints*this.execEvenlyMinDelayMs),setTimeout(n,l,c)}else n(c)})}penalty(e,t=1,r={}){let n=this.getKey(e);return new Promise(s=>{let o=this._getKeySecDuration(r),a=this._memoryStorage.incrby(n,t,o);a.remainingPoints=Math.max(this.points-a.consumedPoints,0),s(a)})}reward(e,t=1,r={}){let n=this.getKey(e);return new Promise(s=>{let o=this._getKeySecDuration(r),a=this._memoryStorage.incrby(n,-t,o);a.remainingPoints=Math.max(this.points-a.consumedPoints,0),s(a)})}block(e,t){let r=t*1e3,n=this.points+1;return this._memoryStorage.set(this.getKey(e),n,t),Promise.resolve(new Jr(0,r===0?-1:r,n))}set(e,t,r){let n=(r>=0?r:this.duration)*1e3;return this._memoryStorage.set(this.getKey(e),t,r),Promise.resolve(new Jr(0,n===0?-1:n,t))}get(e){let t=this._memoryStorage.get(this.getKey(e));return t!==null&&(t.remainingPoints=Math.max(this.points-t.consumedPoints,0)),Promise.resolve(t)}delete(e){return Promise.resolve(this._memoryStorage.delete(this.getKey(e)))}};Zr.exports=wt});var oi=g((Pc,si)=>{var ei=Gr(),vs=jr(),Bs=me(),ri=gt(),Os=k(),v="rate_limiter_flexible",oe=null,ti=function(i,e,t,r){let n;r===null||r===!0||r===!1?n=r:n={remainingPoints:r.remainingPoints,msBeforeNext:r.msBeforeNext,consumedPoints:r.consumedPoints,isFirstInDuration:r.isFirstInDuration},i.send({channel:v,keyPrefix:e.keyPrefix,promiseId:e.promiseId,type:t,data:n})},ii=function(i){setTimeout(()=>{this._initiated?process.send(i):typeof this._promises[i.promiseId]<"u"&&ii.call(this,i)},30)},ne=function(i,e,t,r,n){let s={channel:v,keyPrefix:this.keyPrefix,func:i,promiseId:e,data:{key:t,arg:r,opts:n}};this._initiated?process.send(s):ii.call(this,s)},ni=function(i,e){if(!e||e.channel!==v||typeof this._rateLimiters[e.keyPrefix]>"u")return!1;let t;switch(e.func){case"consume":t=this._rateLimiters[e.keyPrefix].consume(e.data.key,e.data.arg,e.data.opts);break;case"penalty":t=this._rateLimiters[e.keyPrefix].penalty(e.data.key,e.data.arg,e.data.opts);break;case"reward":t=this._rateLimiters[e.keyPrefix].reward(e.data.key,e.data.arg,e.data.opts);break;case"block":t=this._rateLimiters[e.keyPrefix].block(e.data.key,e.data.arg,e.data.opts);break;case"get":t=this._rateLimiters[e.keyPrefix].get(e.data.key,e.data.opts);break;case"delete":t=this._rateLimiters[e.keyPrefix].delete(e.data.key,e.data.opts);break;default:return!1}t&&t.then(r=>{ti(i,e,"resolve",r)}).catch(r=>{ti(i,e,"reject",r)})},Ds=function(i){if(!i||i.channel!==v||i.keyPrefix!==this.keyPrefix)return!1;if(this._promises[i.promiseId]){clearTimeout(this._promises[i.promiseId].timeoutId);let e;switch(i.data===null||i.data===!0||i.data===!1?e=i.data:e=new Os(i.data.remainingPoints,i.data.msBeforeNext,i.data.consumedPoints,i.data.isFirstInDuration),i.type){case"resolve":this._promises[i.promiseId].resolve(e);break;case"reject":this._promises[i.promiseId].reject(e);break;default:throw new Error(`RateLimiterCluster: no such message type '${i.type}'`)}delete this._promises[i.promiseId]}},Fs=function(){return{points:this.points,duration:this.duration,blockDuration:this.blockDuration,execEvenly:this.execEvenly,execEvenlyMinDelayMs:this.execEvenlyMinDelayMs,keyPrefix:this.keyPrefix}},se=function(i,e){let t=process.hrtime(),r=t[0].toString()+t[1].toString();return typeof this._promises[r]<"u"&&(r+=vs.randomBytes(12).toString("base64")),this._promises[r]={resolve:i,reject:e,timeoutId:setTimeout(()=>{delete this._promises[r],e(new Error("RateLimiterCluster timeout: no answer from master in time"))},this.timeoutMs)},r},Et=class{constructor(){if(oe)return oe;this._rateLimiters={},ei.setMaxListeners(0),ei.on("message",(e,t)=>{t&&t.channel===v&&t.type==="init"?(typeof this._rateLimiters[t.opts.keyPrefix]>"u"&&(this._rateLimiters[t.opts.keyPrefix]=new ri(t.opts)),e.send({channel:v,type:"init",keyPrefix:t.opts.keyPrefix})):ni.call(this,e,t)}),oe=this}},_t=class{constructor(e){if(oe)return oe;this._rateLimiters={},e.launchBus((t,r)=>{r.on("process:msg",n=>{let s=n.raw;if(s&&s.channel===v&&s.type==="init")typeof this._rateLimiters[s.opts.keyPrefix]>"u"&&(this._rateLimiters[s.opts.keyPrefix]=new ri(s.opts)),e.sendDataToProcessId(n.process.pm_id,{data:{},topic:v,channel:v,type:"init",keyPrefix:s.opts.keyPrefix},(o,a)=>{o&&console.log(o,a)});else{let o={send:a=>{let c=a;c.topic=v,typeof c.data>"u"&&(c.data={}),e.sendDataToProcessId(n.process.pm_id,c,(l,u)=>{l&&console.log(l,u)})}};ni.call(this,o,s)}})}),oe=this}},xt=class extends Bs{get timeoutMs(){return this._timeoutMs}set timeoutMs(e){this._timeoutMs=typeof e>"u"?5e3:Math.abs(parseInt(e))}constructor(e={}){super(e),process.setMaxListeners(0),this.timeoutMs=e.timeoutMs,this._initiated=!1,process.on("message",t=>{t&&t.channel===v&&t.type==="init"&&t.keyPrefix===this.keyPrefix?this._initiated=!0:Ds.call(this,t)}),process.send({channel:v,type:"init",opts:Fs.call(this)}),this._promises={}}consume(e,t=1,r={}){return new Promise((n,s)=>{let o=se.call(this,n,s);ne.call(this,"consume",o,e,t,r)})}penalty(e,t=1,r={}){return new Promise((n,s)=>{let o=se.call(this,n,s);ne.call(this,"penalty",o,e,t,r)})}reward(e,t=1,r={}){return new Promise((n,s)=>{let o=se.call(this,n,s);ne.call(this,"reward",o,e,t,r)})}block(e,t,r={}){return new Promise((n,s)=>{let o=se.call(this,n,s);ne.call(this,"block",o,e,t,r)})}get(e,t={}){return new Promise((r,n)=>{let s=se.call(this,r,n);ne.call(this,"get",s,e,t)})}delete(e,t={}){return new Promise((r,n)=>{let s=se.call(this,r,n);ne.call(this,"delete",s,e,t)})}};si.exports={RateLimiterClusterMaster:Et,RateLimiterClusterMasterPM2:_t,RateLimiterCluster:xt}});var ci=g((vc,ai)=>{var Us=ie(),qs=k(),St=class extends Us{constructor(e){super(e),this.client=e.storeClient}_getRateLimiterRes(e,t,r){let n=new qs;return n.consumedPoints=parseInt(r.consumedPoints),n.isFirstInDuration=r.consumedPoints===t,n.remainingPoints=Math.max(this.points-n.consumedPoints,0),n.msBeforeNext=r.msBeforeNext,n}_upsert(e,t,r,n=!1,s={}){return new Promise((o,a)=>{let c=Date.now(),l=Math.floor(r/1e3);n?this.client.set(e,t,l,u=>{u?a(u):this.client.set(`${e}_expire`,l>0?c+l*1e3:-1,l,()=>{let h={consumedPoints:t,msBeforeNext:l>0?l*1e3:-1};o(h)})}):this.client.incr(e,t,(u,h)=>{u||h===!1?this.client.add(e,t,l,(d,E)=>{if(d||!E)if(typeof s.attemptNumber>"u"||s.attemptNumber<3){let m=Object.assign({},s);m.attemptNumber=m.attemptNumber?m.attemptNumber+1:1,this._upsert(e,t,r,n,m).then(f=>o(f)).catch(f=>a(f))}else a(new Error("Can not add key"));else this.client.add(`${e}_expire`,l>0?c+l*1e3:-1,l,()=>{let m={consumedPoints:t,msBeforeNext:l>0?l*1e3:-1};o(m)})}):this.client.get(`${e}_expire`,(d,E)=>{if(d)a(d);else{let m=E===!1?0:E,f={consumedPoints:h,msBeforeNext:m>=0?Math.max(m-c,0):-1};o(f)}})})})}_get(e){return new Promise((t,r)=>{let n=Date.now();this.client.get(e,(s,o)=>{o?this.client.get(`${e}_expire`,(a,c)=>{if(a)r(a);else{let l=c===!1?0:c,u={consumedPoints:o,msBeforeNext:l>=0?Math.max(l-n,0):-1};t(u)}}):t(null)})})}_delete(e){return new Promise((t,r)=>{this.client.del(e,(n,s)=>{n?r(n):s===!1?t(s):this.client.del(`${e}_expire`,o=>{o?r(o):t(s)})})})}};ai.exports=St});var hi=g((Oc,li)=>{var ui=k();li.exports=class{constructor(e={}){this.limiter=e.limiter,this.blackList=e.blackList,this.whiteList=e.whiteList,this.isBlackListed=e.isBlackListed,this.isWhiteListed=e.isWhiteListed,this.runActionAnyway=e.runActionAnyway}get limiter(){return this._limiter}set limiter(e){if(typeof e>"u")throw new Error("limiter is not set");this._limiter=e}get runActionAnyway(){return this._runActionAnyway}set runActionAnyway(e){this._runActionAnyway=typeof e>"u"?!1:e}get blackList(){return this._blackList}set blackList(e){this._blackList=Array.isArray(e)?e:[]}get isBlackListed(){return this._isBlackListed}set isBlackListed(e){if(typeof e>"u"&&(e=()=>!1),typeof e!="function")throw new Error("isBlackListed must be function");this._isBlackListed=e}get whiteList(){return this._whiteList}set whiteList(e){this._whiteList=Array.isArray(e)?e:[]}get isWhiteListed(){return this._isWhiteListed}set isWhiteListed(e){if(typeof e>"u"&&(e=()=>!1),typeof e!="function")throw new Error("isWhiteListed must be function");this._isWhiteListed=e}isBlackListedSomewhere(e){return this.blackList.indexOf(e)>=0||this.isBlackListed(e)}isWhiteListedSomewhere(e){return this.whiteList.indexOf(e)>=0||this.isWhiteListed(e)}getBlackRes(){return new ui(0,Number.MAX_SAFE_INTEGER,0,!1)}getWhiteRes(){return new ui(Number.MAX_SAFE_INTEGER,0,0,!1)}rejectBlack(){return Promise.reject(this.getBlackRes())}resolveBlack(){return Promise.resolve(this.getBlackRes())}resolveWhite(){return Promise.resolve(this.getWhiteRes())}consume(e,t=1){let r;return this.isWhiteListedSomewhere(e)?r=this.resolveWhite():this.isBlackListedSomewhere(e)&&(r=this.rejectBlack()),typeof r>"u"?this.limiter.consume(e,t):(this.runActionAnyway&&this.limiter.consume(e,t).catch(()=>{}),r)}block(e,t){let r;return this.isWhiteListedSomewhere(e)?r=this.resolveWhite():this.isBlackListedSomewhere(e)&&(r=this.resolveBlack()),typeof r>"u"?this.limiter.block(e,t):(this.runActionAnyway&&this.limiter.block(e,t).catch(()=>{}),r)}penalty(e,t){let r;return this.isWhiteListedSomewhere(e)?r=this.resolveWhite():this.isBlackListedSomewhere(e)&&(r=this.resolveBlack()),typeof r>"u"?this.limiter.penalty(e,t):(this.runActionAnyway&&this.limiter.penalty(e,t).catch(()=>{}),r)}reward(e,t){let r;return this.isWhiteListedSomewhere(e)?r=this.resolveWhite():this.isBlackListedSomewhere(e)&&(r=this.resolveBlack()),typeof r>"u"?this.limiter.reward(e,t):(this.runActionAnyway&&this.limiter.reward(e,t).catch(()=>{}),r)}get(e){let t;return this.isWhiteListedSomewhere(e)?t=this.resolveWhite():this.isBlackListedSomewhere(e)&&(t=this.resolveBlack()),typeof t>"u"||this.runActionAnyway?this.limiter.get(e):t}delete(e){return this.limiter.delete(e)}}});var di=g((Fc,fi)=>{var $s=me();fi.exports=class{constructor(...e){if(e.length<1)throw new Error("RateLimiterUnion: at least one limiter have to be passed");e.forEach(t=>{if(!(t instanceof $s))throw new Error("RateLimiterUnion: all limiters have to be instance of RateLimiterAbstract")}),this._limiters=e}consume(e,t=1){return new Promise((r,n)=>{let s=[];this._limiters.forEach(o=>{s.push(o.consume(e,t).catch(a=>({rejected:!0,rej:a})))}),Promise.all(s).then(o=>{let a={},c=!1;o.forEach(l=>{l.rejected===!0&&(c=!0)});for(let l=0;l<o.length;l++)c&&o[l].rejected===!0?a[this._limiters[l].keyPrefix]=o[l].rej:c||(a[this._limiters[l].keyPrefix]=o[l]);c?n(a):r(a)})})}}});var pi=g((qc,mi)=>{mi.exports=class extends Error{constructor(e,t){super(),Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor),this.name="CustomError",this.message=e,t&&(this.extra=t)}}});var gi=g((zc,wi)=>{var bi=pi(),yi=4294967295,Ct="limiter";wi.exports=class{constructor(e,t={maxQueueSize:yi}){this._queueLimiters={KEY_DEFAULT:new Ie(e,t)},this._limiterFlexible=e,this._maxQueueSize=t.maxQueueSize}getTokensRemaining(e=Ct){return this._queueLimiters[e]?this._queueLimiters[e].getTokensRemaining():Promise.resolve(this._limiterFlexible.points)}removeTokens(e,t=Ct){return this._queueLimiters[t]||(this._queueLimiters[t]=new Ie(this._limiterFlexible,{key:t,maxQueueSize:this._maxQueueSize})),this._queueLimiters[t].removeTokens(e)}};var Ie=class{constructor(e,t={maxQueueSize:yi,key:Ct}){this._key=t.key,this._waitTimeout=null,this._queue=[],this._limiterFlexible=e,this._maxQueueSize=t.maxQueueSize}getTokensRemaining(){return this._limiterFlexible.get(this._key).then(e=>e!==null?e.remainingPoints:this._limiterFlexible.points)}removeTokens(e){let t=this;return new Promise((r,n)=>{if(e>t._limiterFlexible.points){n(new bi(`Requested tokens ${e} exceeds maximum ${t._limiterFlexible.points} tokens per interval`));return}t._queue.length>0?t._queueRequest.call(t,r,n,e):t._limiterFlexible.consume(t._key,e).then(s=>{r(s.remainingPoints)}).catch(s=>{s instanceof Error?n(s):(t._queueRequest.call(t,r,n,e),t._waitTimeout===null&&(t._waitTimeout=setTimeout(t._processFIFO.bind(t),s.msBeforeNext)))})})}_queueRequest(e,t,r){let n=this;n._queue.length<n._maxQueueSize?n._queue.push({resolve:e,reject:t,tokens:r}):t(new bi(`Number of requests reached it's maximum ${n._maxQueueSize}`))}_processFIFO(){let e=this;if(e._waitTimeout!==null&&(clearTimeout(e._waitTimeout),e._waitTimeout=null),e._queue.length===0)return;let t=e._queue.shift();e._limiterFlexible.consume(e._key,t.tokens).then(r=>{t.resolve(r.remainingPoints),e._processFIFO.call(e)}).catch(r=>{r instanceof Error?(t.reject(r),e._processFIFO.call(e)):(e._queue.unshift(t),e._waitTimeout===null&&(e._waitTimeout=setTimeout(e._processFIFO.bind(e),r.msBeforeNext)))})}}});var _i=g((Kc,Ei)=>{var Rt=k();Ei.exports=class{constructor(e,t){this._rateLimiter=e,this._burstLimiter=t}_combineRes(e,t){return new Rt(e.remainingPoints,Math.min(e.msBeforeNext,t.msBeforeNext),e.consumedPoints,e.isFirstInDuration)}consume(e,t=1,r={}){return this._rateLimiter.consume(e,t,r).catch(n=>n instanceof Rt?this._burstLimiter.consume(e,t,r).then(s=>Promise.resolve(this._combineRes(n,s))).catch(s=>s instanceof Rt?Promise.reject(this._combineRes(n,s)):Promise.reject(s)):Promise.reject(n))}get(e){return Promise.all([this._rateLimiter.get(e),this._burstLimiter.get(e)]).then(([t,r])=>this._combineRes(t,r))}get points(){return this._rateLimiter.points}}});var Si=g((Wc,xi)=>{var zs=Fr(),Vs=$r(),Ks=Vr(),Ws=Wr(),{RateLimiterClusterMaster:Gs,RateLimiterClusterMasterPM2:js,RateLimiterCluster:Hs}=oi(),Ys=gt(),Qs=ci(),Xs=hi(),Js=di(),Zs=gi(),eo=_i(),to=k();xi.exports={RateLimiterRedis:zs,RateLimiterMongo:Vs,RateLimiterMySQL:Ks,RateLimiterPostgres:Ws,RateLimiterMemory:Ys,RateLimiterMemcache:Qs,RateLimiterClusterMaster:Gs,RateLimiterClusterMasterPM2:js,RateLimiterCluster:Hs,RLWrapperBlackAndWhite:Xs,RateLimiterUnion:Js,RateLimiterQueue:Zs,BurstyRateLimiter:eo,RateLimiterRes:to}});var ao={};M(ao,{mplex:()=>oo});var ye=class{constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},H=class{constructor(e={}){this.hwm=e.splitLimit??16,this.head=new ye(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new ye(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};function It(i={}){return Nt(t=>{let r=t.shift();if(r==null)return{done:!0};if(r.error!=null)throw r.error;return{done:r.done===!0,value:r.value}},i)}function Mt(i={}){return Nt(t=>{let r,n=[];for(;!t.isEmpty()&&(r=t.shift(),r!=null);){if(r.error!=null)throw r.error;r.done===!1&&n.push(r.value)}return r==null?{done:!0}:{done:r.done===!0,value:n}},i)}function Nt(i,e){e=e??{};let t=e.onEnd,r=new H,n,s,o,a=async()=>r.isEmpty()?o?{done:!0}:await new Promise((f,b)=>{s=x=>{s=null,r.push(x);try{f(i(r))}catch(R){b(R)}return n}}):i(r),c=f=>s!=null?s(f):(r.push(f),n),l=f=>(r=new H,s!=null?s({error:f}):(r.push({error:f}),n)),u=f=>{if(o)return n;if(e?.objectMode!==!0&&f?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return c({done:!1,value:f})},h=f=>o?n:(o=!0,f!=null?l(f):c({done:!0})),d=()=>(r=new H,h(),{done:!0}),E=f=>(h(f),{done:!0});if(n={[Symbol.asyncIterator](){return this},next:a,return:d,throw:E,push:u,end:h,get readableLength(){return r.size}},t==null)return n;let m=n;return n={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(f){return m.throw(f),t!=null&&(t(f),t=void 0),{done:!0}},return(){return m.return(),t!=null&&(t(),t=void 0),{done:!0}},push:u,end(f){return m.end(f),t!=null&&(t(f),t=void 0),n},get readableLength(){return m.readableLength}},n}var ae=class extends Error{constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function kt(i){if(i!=null){if(typeof i[Symbol.iterator]=="function")return i[Symbol.iterator]();if(typeof i[Symbol.asyncIterator]=="function")return i[Symbol.asyncIterator]();if(typeof i.next=="function")return i}throw new Error("argument is not an iterator or iterable")}function we(i,e,t){let r=t??{},n=kt(i);async function*s(){let o,a=()=>{o?.()};for(e.addEventListener("abort",a);;){let c;try{if(e.aborted){let{abortMessage:u,abortCode:h}=r;throw new ae(u,h)}let l=new Promise((u,h)=>{o=()=>{let{abortMessage:d,abortCode:E}=r;h(new ae(d,E))}});c=await Promise.race([l,n.next()]),o=null}catch(l){e.removeEventListener("abort",a);let u=l.type==="aborted"&&e.aborted;if(u&&r.onAbort!=null&&await r.onAbort(i),typeof n.return=="function")try{let h=n.return();h instanceof Promise&&h.catch(d=>{r.onReturnError!=null&&r.onReturnError(d)})}catch(h){r.onReturnError!=null&&r.onReturnError(h)}if(u&&r.returnOnAbort===!0)return;throw l}if(c.done===!0)break;yield c.value}e.removeEventListener("abort",a)}return s()}var Y=K(zt(),1);function q(i){return globalThis.Buffer!=null?new Uint8Array(i.buffer,i.byteOffset,i.byteLength):i}function F(i=0){return globalThis.Buffer?.alloc!=null?q(globalThis.Buffer.alloc(i)):new Uint8Array(i)}function $(i=0){return globalThis.Buffer?.allocUnsafe!=null?q(globalThis.Buffer.allocUnsafe(i)):new Uint8Array(i)}function ge(i,e){e==null&&(e=i.reduce((n,s)=>n+s.length,0));let t=$(e),r=0;for(let n of i)t.set(n,r),r+=n.length;return q(t)}function Pe(i,e){if(i===e)return!0;if(i.byteLength!==e.byteLength)return!1;for(let t=0;t<i.byteLength;t++)if(i[t]!==e[t])return!1;return!0}var Kt=Symbol.for("@achingbrain/uint8arraylist");function Vt(i,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let r of i){let n=t+r.byteLength;if(e<n)return{buf:r,index:e-t};t=n}throw new RangeError("index is out of bounds")}function Ee(i){return Boolean(i?.[Kt])}var T=class{constructor(...e){Object.defineProperty(this,Kt,{value:!0}),this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let r of e)if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.push(r);else if(Ee(r))t+=r.byteLength,this.bufs.push(...r.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let r of e.reverse())if(r instanceof Uint8Array)t+=r.byteLength,this.bufs.unshift(r);else if(Ee(r))t+=r.byteLength,this.bufs.unshift(...r.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Vt(this.bufs,e);return t.buf[t.index]}set(e,t){let r=Vt(this.bufs,e);r.buf[r.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let r=0;r<e.length;r++)this.set(t+r,e[r]);else if(Ee(e))for(let r=0;r<e.length;r++)this.set(t+r,e.get(r));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:r,length:n}=this._subList(e,t);return ge(r,n)}subarray(e,t){let{bufs:r,length:n}=this._subList(e,t);return r.length===1?r[0]:ge(r,n)}sublist(e,t){let{bufs:r,length:n}=this._subList(e,t),s=new T;return s.length=n,s.bufs=r,s}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:[...this.bufs],length:this.length};let r=[],n=0;for(let s=0;s<this.bufs.length;s++){let o=this.bufs[s],a=n,c=a+o.byteLength;if(n=c,e>=c)continue;let l=e>=a&&e<c,u=t>a&&t<=c;if(l&&u){if(e===a&&t===c){r.push(o);break}let h=e-a;r.push(o.subarray(h,h+(t-e)));break}if(l){if(e===0){r.push(o);continue}r.push(o.subarray(e-a));continue}if(u){if(t===c){r.push(o);break}r.push(o.subarray(0,t-a));break}r.push(o)}return{bufs:r,length:t-e}}indexOf(e,t=0){if(!Ee(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let r=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let n=r.byteLength;if(n===0)throw new TypeError("search must be at least 1 byte long");let s=256,o=new Int32Array(s);for(let h=0;h<s;h++)o[h]=-1;for(let h=0;h<n;h++)o[r[h]]=h;let a=o,c=this.byteLength-r.byteLength,l=r.byteLength-1,u;for(let h=t;h<=c;h+=u){u=0;for(let d=l;d>=0;d--){let E=this.get(h+d);if(r[d]!==E){u=Math.max(1,d-a[E]);break}}if(u===0)return h}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let r=$(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setInt8(0,t),this.write(r,e)}getInt16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt16(0,t)}setInt16(e,t,r){let n=F(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt16(0,t,r),this.write(n,e)}getInt32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt32(0,t)}setInt32(e,t,r){let n=F(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt32(0,t,r),this.write(n,e)}getBigInt64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigInt64(0,t)}setBigInt64(e,t,r){let n=F(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigInt64(0,t,r),this.write(n,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let r=$(1);new DataView(r.buffer,r.byteOffset,r.byteLength).setUint8(0,t),this.write(r,e)}getUint16(e,t){let r=this.subarray(e,e+2);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint16(0,t)}setUint16(e,t,r){let n=F(2);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint16(0,t,r),this.write(n,e)}getUint32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint32(0,t)}setUint32(e,t,r){let n=F(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint32(0,t,r),this.write(n,e)}getBigUint64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getBigUint64(0,t)}setBigUint64(e,t,r){let n=F(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setBigUint64(0,t,r),this.write(n,e)}getFloat32(e,t){let r=this.subarray(e,e+4);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat32(0,t)}setFloat32(e,t,r){let n=F(4);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat32(0,t,r),this.write(n,e)}getFloat64(e,t){let r=this.subarray(e,e+8);return new DataView(r.buffer,r.byteOffset,r.byteLength).getFloat64(0,t)}setFloat64(e,t,r){let n=F(8);new DataView(n.buffer,n.byteOffset,n.byteLength).setFloat64(0,t,r),this.write(n,e)}equals(e){if(e==null||!(e instanceof T)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!Pe(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let r=new T;return r.bufs=e,t==null&&(t=e.reduce((n,s)=>n+s.byteLength,0)),r.length=t,r}};function ve(i){return new Uint8Array(i)}var w;(function(i){i[i.NEW_STREAM=0]="NEW_STREAM",i[i.MESSAGE_RECEIVER=1]="MESSAGE_RECEIVER",i[i.MESSAGE_INITIATOR=2]="MESSAGE_INITIATOR",i[i.CLOSE_RECEIVER=3]="CLOSE_RECEIVER",i[i.CLOSE_INITIATOR=4]="CLOSE_INITIATOR",i[i.RESET_RECEIVER=5]="RESET_RECEIVER",i[i.RESET_INITIATOR=6]="RESET_INITIATOR"})(w||(w={}));var ce=Object.freeze({0:"NEW_STREAM",1:"MESSAGE_RECEIVER",2:"MESSAGE_INITIATOR",3:"CLOSE_RECEIVER",4:"CLOSE_INITIATOR",5:"RESET_RECEIVER",6:"RESET_INITIATOR"}),Be=Object.freeze({NEW_STREAM:w.NEW_STREAM,MESSAGE:w.MESSAGE_INITIATOR,CLOSE:w.CLOSE_INITIATOR,RESET:w.RESET_INITIATOR}),Wt=Object.freeze({MESSAGE:w.MESSAGE_RECEIVER,CLOSE:w.CLOSE_RECEIVER,RESET:w.RESET_RECEIVER});function _e(){let i={};return i.promise=new Promise((e,t)=>{i.resolve=e,i.reject=t}),i}var Gt=1024*1024,Gi=(i,e)=>e.append(i);async function*ji(i,e={}){let t=new T,r=!1,n=_e(),s=Number(e.size??Gt);(isNaN(s)||s===0||s<0)&&(s=Gt);let o=e.yieldAfter??0,a=e.serialize??Gi;for(Promise.resolve().then(async()=>{try{let c;for await(let l of i){if(a(l,t),t.byteLength>=s){clearTimeout(c),n.resolve();continue}c=setTimeout(()=>{n.resolve()},o)}clearTimeout(c),n.resolve()}catch(c){n.reject(c)}finally{r=!0}});!r;)if(await n.promise,n=_e(),t.byteLength>0){let c=t;t=new T,yield c.subarray()}}var jt=ji;var Oe=10*1024,De=class{constructor(){this._pool=ve(Oe),this._poolOffset=0}write(e,t){let r=this._pool,n=this._poolOffset;Y.default.encode(e.id<<3|e.type,r,n),n+=Y.default.encode.bytes??0,(e.type===w.NEW_STREAM||e.type===w.MESSAGE_INITIATOR||e.type===w.MESSAGE_RECEIVER)&&e.data!=null?Y.default.encode(e.data.length,r,n):Y.default.encode(0,r,n),n+=Y.default.encode.bytes??0;let s=r.subarray(this._poolOffset,n);Oe-n<100?(this._pool=ve(Oe),this._poolOffset=0):this._poolOffset=n,t.append(s),(e.type===w.NEW_STREAM||e.type===w.MESSAGE_INITIATOR||e.type===w.MESSAGE_RECEIVER)&&e.data!=null&&t.append(e.data)}},Ht=new De;async function*Yt(i,e=0){if(e==null||e===0){for await(let t of i){let r=new T;for(let n of t)Ht.write(n,r);yield r.subarray()}return}yield*jt(i,{size:e,serialize:(t,r)=>{for(let n of t)Ht.write(n,r)}})}var Fe=1<<20,Hi=4<<20,xe=class{constructor(e=Fe,t=Hi){this._buffer=new T,this._headerInfo=null,this._maxMessageSize=e,this._maxUnprocessedMessageQueueSize=t}write(e){if(e==null||e.length===0)return[];if(this._buffer.append(e),this._buffer.byteLength>this._maxUnprocessedMessageQueueSize)throw Object.assign(new Error("unprocessed message queue size too large!"),{code:"ERR_MSG_QUEUE_TOO_BIG"});let t=[];for(;this._buffer.length!==0;){if(this._headerInfo==null)try{this._headerInfo=this._decodeHeader(this._buffer)}catch(l){if(l.code==="ERR_MSG_TOO_BIG")throw l;break}let{id:r,type:n,length:s,offset:o}=this._headerInfo;if(this._buffer.length-o<s)break;let c={id:r,type:n};(n===w.NEW_STREAM||n===w.MESSAGE_INITIATOR||n===w.MESSAGE_RECEIVER)&&(c.data=this._buffer.sublist(o,o+s)),t.push(c),this._buffer.consume(o+s),this._headerInfo=null}return t}_decodeHeader(e){let{value:t,offset:r}=Xt(e),{value:n,offset:s}=Xt(e,r),o=t&7;if(ce[o]==null)throw new Error(`Invalid type received: ${o}`);if(n>this._maxMessageSize)throw Object.assign(new Error("message size too large!"),{code:"ERR_MSG_TOO_BIG"});return{id:t>>3,type:o,offset:r+s,length:n}}},Yi=128,Qt=127;function Xt(i,e=0){let t=0,r=0,n=e,s,o=i.length;do{if(n>=o||r>49)throw e=0,new RangeError("Could not decode varint");s=i.get(n++),t+=r<28?(s&Qt)<<r:(s&Qt)*Math.pow(2,r),r+=7}while(s>=Yi);return e=n-e,{value:t,offset:e}}var Le=K(Ue(),1);var Ar=K($e(),1);var Ge={};M(Ge,{identity:()=>rn});function Xi(i,e){if(i.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),r=0;r<t.length;r++)t[r]=255;for(var n=0;n<i.length;n++){var s=i.charAt(n),o=s.charCodeAt(0);if(t[o]!==255)throw new TypeError(s+" is ambiguous");t[o]=n}var a=i.length,c=i.charAt(0),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function h(m){if(m instanceof Uint8Array||(ArrayBuffer.isView(m)?m=new Uint8Array(m.buffer,m.byteOffset,m.byteLength):Array.isArray(m)&&(m=Uint8Array.from(m))),!(m instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(m.length===0)return"";for(var f=0,b=0,x=0,R=m.length;x!==R&&m[x]===0;)x++,f++;for(var A=(R-x)*u+1>>>0,_=new Uint8Array(A);x!==R;){for(var L=m[x],y=0,p=A-1;(L!==0||y<b)&&p!==-1;p--,y++)L+=256*_[p]>>>0,_[p]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");b=y,x++}for(var I=A-b;I!==A&&_[I]===0;)I++;for(var j=c.repeat(f);I<A;++I)j+=i.charAt(_[I]);return j}function d(m){if(typeof m!="string")throw new TypeError("Expected String");if(m.length===0)return new Uint8Array;var f=0;if(m[f]!==" "){for(var b=0,x=0;m[f]===c;)b++,f++;for(var R=(m.length-f)*l+1>>>0,A=new Uint8Array(R);m[f];){var _=t[m.charCodeAt(f)];if(_===255)return;for(var L=0,y=R-1;(_!==0||L<x)&&y!==-1;y--,L++)_+=a*A[y]>>>0,A[y]=_%256>>>0,_=_/256>>>0;if(_!==0)throw new Error("Non-zero carry");x=L,f++}if(m[f]!==" "){for(var p=R-x;p!==R&&A[p]===0;)p++;for(var I=new Uint8Array(b+(R-p)),j=b;p!==R;)I[j++]=A[p++];return I}}}function E(m){var f=d(m);if(f)return f;throw new Error(`Non-${e} character`)}return{encode:h,decodeUnsafe:d,decode:E}}var Ji=Xi,Zi=Ji,tr=Zi;var Qo=new Uint8Array(0);var rr=(i,e)=>{if(i===e)return!0;if(i.byteLength!==e.byteLength)return!1;for(let t=0;t<i.byteLength;t++)if(i[t]!==e[t])return!1;return!0},U=i=>{if(i instanceof Uint8Array&&i.constructor.name==="Uint8Array")return i;if(i instanceof ArrayBuffer)return new Uint8Array(i);if(ArrayBuffer.isView(i))return new Uint8Array(i.buffer,i.byteOffset,i.byteLength);throw new Error("Unknown type, must be binary type")};var ir=i=>new TextEncoder().encode(i),nr=i=>new TextDecoder().decode(i);var ze=class{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")}},Ve=class{constructor(e,t,r){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=r}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return or(this,e)}},Ke=class{constructor(e){this.decoders=e}or(e){return or(this,e)}decode(e){let 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`)}},or=(i,e)=>new Ke({...i.decoders||{[i.prefix]:i},...e.decoders||{[e.prefix]:e}}),We=class{constructor(e,t,r,n){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=n,this.encoder=new ze(e,t,r),this.decoder=new Ve(e,t,n)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}},Q=({name:i,prefix:e,encode:t,decode:r})=>new We(i,e,t,r),z=({prefix:i,name:e,alphabet:t})=>{let{encode:r,decode:n}=tr(t,e);return Q({prefix:i,name:e,encode:r,decode:s=>U(n(s))})},en=(i,e,t,r)=>{let n={};for(let u=0;u<e.length;++u)n[e[u]]=u;let s=i.length;for(;i[s-1]==="=";)--s;let o=new Uint8Array(s*t/8|0),a=0,c=0,l=0;for(let u=0;u<s;++u){let h=n[i[u]];if(h===void 0)throw new SyntaxError(`Non-${r} character`);c=c<<t|h,a+=t,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o},tn=(i,e,t)=>{let r=e[e.length-1]==="=",n=(1<<t)-1,s="",o=0,a=0;for(let c=0;c<i.length;++c)for(a=a<<8|i[c],o+=8;o>t;)o-=t,s+=e[n&a>>o];if(o&&(s+=e[n&a<<t-o]),r)for(;s.length*t&7;)s+="=";return s},S=({name:i,prefix:e,bitsPerChar:t,alphabet:r})=>Q({prefix:e,name:i,encode(n){return tn(n,r,t)},decode(n){return en(n,r,t,i)}});var rn=Q({prefix:"\0",name:"identity",encode:i=>nr(i),decode:i=>ir(i)});var je={};M(je,{base2:()=>nn});var nn=S({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var He={};M(He,{base8:()=>sn});var sn=S({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ye={};M(Ye,{base10:()=>on});var on=z({prefix:"9",name:"base10",alphabet:"0123456789"});var Qe={};M(Qe,{base16:()=>an,base16upper:()=>cn});var an=S({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),cn=S({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Xe={};M(Xe,{base32:()=>V,base32hex:()=>fn,base32hexpad:()=>mn,base32hexpadupper:()=>pn,base32hexupper:()=>dn,base32pad:()=>ln,base32padupper:()=>hn,base32upper:()=>un,base32z:()=>bn});var V=S({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),un=S({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ln=S({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),hn=S({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),fn=S({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dn=S({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),mn=S({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),pn=S({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),bn=S({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Je={};M(Je,{base36:()=>yn,base36upper:()=>wn});var yn=z({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),wn=z({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ze={};M(Ze,{base58btc:()=>P,base58flickr:()=>gn});var P=z({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),gn=z({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var tt={};M(tt,{base64:()=>et,base64pad:()=>En,base64url:()=>_n,base64urlpad:()=>xn});var et=S({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),En=S({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_n=S({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),xn=S({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var rt={};M(rt,{base256emoji:()=>Tn});var ar=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Sn=ar.reduce((i,e,t)=>(i[t]=e,i),[]),Cn=ar.reduce((i,e,t)=>(i[e.codePointAt(0)]=t,i),[]);function Rn(i){return i.reduce((e,t)=>(e+=Sn[t],e),"")}function An(i){let e=[];for(let t of i){let r=Cn[t.codePointAt(0)];if(r===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(r)}return new Uint8Array(e)}var Tn=Q({prefix:"\u{1F680}",name:"base256emoji",encode:Rn,decode:An});var ot={};M(ot,{sha256:()=>Gn,sha512:()=>jn});var Ln=lr,cr=128,In=127,Mn=~In,Nn=Math.pow(2,31);function lr(i,e,t){e=e||[],t=t||0;for(var r=t;i>=Nn;)e[t++]=i&255|cr,i/=128;for(;i&Mn;)e[t++]=i&255|cr,i>>>=7;return e[t]=i|0,lr.bytes=t-r+1,e}var kn=it,Pn=128,ur=127;function it(i,r){var t=0,r=r||0,n=0,s=r,o,a=i.length;do{if(s>=a)throw it.bytes=0,new RangeError("Could not decode varint");o=i[s++],t+=n<28?(o&ur)<<n:(o&ur)*Math.pow(2,n),n+=7}while(o>=Pn);return it.bytes=s-r,t}var vn=Math.pow(2,7),Bn=Math.pow(2,14),On=Math.pow(2,21),Dn=Math.pow(2,28),Fn=Math.pow(2,35),Un=Math.pow(2,42),qn=Math.pow(2,49),$n=Math.pow(2,56),zn=Math.pow(2,63),Vn=function(i){return i<vn?1:i<Bn?2:i<On?3:i<Dn?4:i<Fn?5:i<Un?6:i<qn?7:i<$n?8:i<zn?9:10},Kn={encode:Ln,decode:kn,encodingLength:Vn},Wn=Kn,ue=Wn;var le=(i,e=0)=>[ue.decode(i,e),ue.decode.bytes],X=(i,e,t=0)=>(ue.encode(i,e,t),e),J=i=>ue.encodingLength(i);var W=(i,e)=>{let t=e.byteLength,r=J(i),n=r+J(t),s=new Uint8Array(n+t);return X(i,s,0),X(t,s,r),s.set(e,n),new Z(i,t,e,s)},hr=i=>{let e=U(i),[t,r]=le(e),[n,s]=le(e.subarray(r)),o=e.subarray(r+s);if(o.byteLength!==n)throw new Error("Incorrect length");return new Z(t,n,o,e)},fr=(i,e)=>{if(i===e)return!0;{let t=e;return i.code===t.code&&i.size===t.size&&t.bytes instanceof Uint8Array&&rr(i.bytes,t.bytes)}},Z=class{constructor(e,t,r,n){this.code=e,this.size=t,this.digest=r,this.bytes=n}};var st=({name:i,code:e,encode:t})=>new nt(i,e,t),nt=class{constructor(e,t,r){this.name=e,this.code=t,this.encode=r}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?W(this.code,t):t.then(r=>W(this.code,r))}else throw Error("Unknown type, must be binary type")}};var mr=i=>async e=>new Uint8Array(await crypto.subtle.digest(i,e)),Gn=st({name:"sha2-256",code:18,encode:mr("SHA-256")}),jn=st({name:"sha2-512",code:19,encode:mr("SHA-512")});var at={};M(at,{identity:()=>Qn});var pr=0,Hn="identity",br=U,Yn=i=>W(pr,br(i)),Qn={code:pr,name:Hn,encode:br,digest:Yn};var ya=new TextEncoder,wa=new TextDecoder;var Zn=(i,e)=>{let{bytes:t,version:r}=i;switch(r){case 0:return ts(t,ct(i),e||P.encoder);default:return rs(t,ct(i),e||V.encoder)}},yr=new WeakMap,ct=i=>{let e=yr.get(i);if(e==null){let t=new Map;return yr.set(i,t),t}return e},C=class{constructor(e,t,r,n){this.code=t,this.version=e,this.multihash=r,this.bytes=n,this["/"]=n}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==fe)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==is)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return C.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,r=W(e,t);return C.createV1(this.code,r)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return C.equals(this,e)}static equals(e,t){let r=t;return r&&e.code===r.code&&e.version===r.version&&fr(e.multihash,r.multihash)}toString(e){return Zn(this,e)}toJSON(){return{code:this.code,version:this.version,hash:this.multihash.bytes}}link(){return this}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof C)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:r,code:n,multihash:s,bytes:o}=t;return new C(r,n,s,o||wr(r,n,s.bytes))}else if(t[ns]===!0){let{version:r,multihash:n,code:s}=t,o=hr(n);return C.create(r,s,o)}else return null}static create(e,t,r){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(r.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==fe)throw new Error(`Version 0 CID must use dag-pb (code: ${fe}) block encoding`);return new C(e,t,r,r.bytes)}case 1:{let n=wr(e,t,r.bytes);return new C(e,t,r,n)}default:throw new Error("Invalid version")}}static createV0(e){return C.create(0,fe,e)}static createV1(e,t){return C.create(1,e,t)}static decode(e){let[t,r]=C.decodeFirst(e);if(r.length)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=C.inspectBytes(e),r=t.size-t.multihashSize,n=U(e.subarray(r,r+t.multihashSize));if(n.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=n.subarray(t.multihashSize-t.digestSize),o=new Z(t.multihashCode,t.digestSize,s,n);return[t.version===0?C.createV0(o):C.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0,r=()=>{let[h,d]=le(e.subarray(t));return t+=d,h},n=r(),s=fe;if(n===18?(n=0,t=0):s=r(),n!==0&&n!==1)throw new RangeError(`Invalid CID version ${n}`);let o=t,a=r(),c=r(),l=t+c,u=l-o;return{version:n,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(e,t){let[r,n]=es(e,t),s=C.decode(n);return ct(s).set(r,e),s}},es=(i,e)=>{switch(i[0]){case"Q":{let t=e||P;return[P.prefix,t.decode(`${P.prefix}${i}`)]}case P.prefix:{let t=e||P;return[P.prefix,t.decode(i)]}case V.prefix:{let t=e||V;return[V.prefix,t.decode(i)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[i[0],e.decode(i)]}}},ts=(i,e,t)=>{let{prefix:r}=t;if(r!==P.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let n=e.get(r);if(n==null){let s=t.encode(i).slice(1);return e.set(r,s),s}else return n},rs=(i,e,t)=>{let{prefix:r}=t,n=e.get(r);if(n==null){let s=t.encode(i);return e.set(r,s),s}else return n},fe=112,is=18,wr=(i,e,t)=>{let r=J(i),n=r+J(e),s=new Uint8Array(n+t.byteLength);return X(i,s,0),X(e,s,r),s.set(t,n),s},ns=Symbol.for("@ipld/js-cid/CID");var ut={...Ge,...je,...He,...Ye,...Qe,...Xe,...Je,...Ze,...tt,...rt},La={...ot,...at};function Er(i,e,t,r){return{name:i,prefix:e,encoder:{name:i,prefix:e,encode:t},decoder:{decode:r}}}var gr=Er("utf8","u",i=>"u"+new TextDecoder("utf8").decode(i),i=>new TextEncoder().encode(i.substring(1))),lt=Er("ascii","a",i=>{let e="a";for(let t=0;t<i.length;t++)e+=String.fromCharCode(i[t]);return e},i=>{i=i.substring(1);let e=$(i.length);for(let t=0;t<i.length;t++)e[t]=i.charCodeAt(t);return e}),ss={utf8:gr,"utf-8":gr,hex:ut.base16,latin1:lt,ascii:lt,binary:lt,...ut},Ce=ss;function ht(i,e="utf8"){let t=Ce[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?q(globalThis.Buffer.from(i,"utf-8")):t.decoder.decode(`${t.prefix}${i}`)}var D=K(Rr(),1);D.default.formatters.b=i=>i==null?"undefined":P.baseEncode(i);D.default.formatters.t=i=>i==null?"undefined":V.baseEncode(i);D.default.formatters.m=i=>i==null?"undefined":et.baseEncode(i);D.default.formatters.p=i=>i==null?"undefined":i.toString();D.default.formatters.c=i=>i==null?"undefined":i.toString();D.default.formatters.k=i=>i==null?"undefined":i.toString();function Te(i){return Object.assign((0,D.default)(i),{error:(0,D.default)(`${i}:error`),trace:(0,D.default)(`${i}:trace`)})}var B=Te("libp2p:mplex:stream"),ft="ERR_STREAM_RESET",ws="ERR_STREAM_ABORT",gs="ERR_SINK_ENDED",Es="ERR_DOUBLE_SINK";function Tr(i){let{id:e,name:t,send:r,onEnd:n,type:s="initiator",maxMsgSize:o=Fe}=i,a=new AbortController,c=new AbortController,l=new AbortController,u=s==="initiator"?Be:Wt,h=s==="initiator"?`i${e}`:`r${e}`,d=`${t??e}`,E=!1,m=!1,f=!1,b,x={open:Date.now()},R=y=>{E||(E=!0,B.trace("%s stream %s source end - err: %o",s,d,y),y!=null&&b==null&&(b=y),m&&(L.stat.timeline.close=Date.now(),n?.(b)))},A=y=>{m||(m=!0,B.trace("%s stream %s sink end - err: %o",s,d,y),y!=null&&b==null&&(b=y),E&&(x.close=Date.now(),n?.(b)))},_=It({onEnd:R}),L={close:()=>{B.trace("%s stream %s close",s,d),L.closeRead(),L.closeWrite()},closeRead:()=>{B.trace("%s stream %s closeRead",s,d),!E&&_.end()},closeWrite:()=>{if(B.trace("%s stream %s closeWrite",s,d),!m){l.abort();try{r({id:e,type:u.CLOSE})}catch(y){B.trace("%s stream %s error sending close",s,t,y)}A()}},abort:y=>{B.trace("%s stream %s abort",s,d,y),_.end(y),a.abort(),A(y)},reset:()=>{let y=(0,Le.default)(new Error("stream reset"),ft);c.abort(),_.end(y),A(y)},sink:async y=>{if(f)throw(0,Le.default)(new Error("sink already called on stream"),Es);if(f=!0,m)throw(0,Le.default)(new Error("stream closed for writing"),gs);y=we(y,(0,Ar.anySignal)([a.signal,c.signal,l.signal]));try{s==="initiator"&&r({id:e,type:Be.NEW_STREAM,data:new T(ht(d))});for await(let p of y)for(;p.length>0;){if(p.length<=o){r({id:e,type:u.MESSAGE,data:p instanceof Uint8Array?new T(p):p});break}p=p instanceof Uint8Array?new T(p):p,r({id:e,type:u.MESSAGE,data:p.sublist(0,o)}),p.consume(o)}}catch(p){if(p.type==="aborted"&&p.message==="The operation was aborted"){if(l.signal.aborted)return;c.signal.aborted&&(p.message="stream reset",p.code=ft),a.signal.aborted&&(p.message="stream aborted",p.code=ws)}if(p.code===ft)B.trace("%s stream %s reset",s,t);else{B.trace("%s stream %s error",s,t,p);try{r({id:e,type:u.RESET})}catch(I){B.trace("%s stream %s error sending reset",s,t,I)}}_.end(p),A(p);return}try{r({id:e,type:u.CLOSE})}catch(p){B.trace("%s stream %s error sending close",s,t,p)}A()},source:_,sourcePush:y=>{_.push(y)},sourceReadableLength(){return _.readableLength},stat:{direction:s==="initiator"?"outbound":"inbound",timeline:x},metadata:{},id:h};return L}function de(i,e="utf8"){let t=Ce[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(i.buffer,i.byteOffset,i.byteLength).toString("utf8"):t.encoder.encode(i).substring(1)}var At=K(Ue(),1),Ri=K(Si(),1),Ai=K($e(),1),O=Te("libp2p:mplex"),ro=1024,io=1024,no=1024*1024*4,so=5;function Ci(i){let e={...i,type:`${ce[i.type]} (${i.type})`};return i.type===w.NEW_STREAM&&(e.data=de(i.data instanceof Uint8Array?i.data:i.data.subarray())),(i.type===w.MESSAGE_INITIATOR||i.type===w.MESSAGE_RECEIVER)&&(e.data=de(i.data instanceof Uint8Array?i.data:i.data.subarray(),"base16")),e}var Me=class{constructor(e){this.protocol="/mplex/6.7.0",e=e??{},this._streamId=0,this._streams={initiators:new Map,receivers:new Map},this._init=e,this.sink=this._createSink();let t=this._createSource();this._source=t,this.source=t,this.closeController=new AbortController,this.rateLimiter=new Ri.RateLimiterMemory({points:e.disconnectThreshold??so,duration:1})}get streams(){let e=[];for(let t of this._streams.initiators.values())e.push(t);for(let t of this._streams.receivers.values())e.push(t);return e}newStream(e){if(this.closeController.signal.aborted)throw new Error("Muxer already closed");let t=this._streamId++;e=e==null?t.toString():e.toString();let r=this._streams.initiators;return this._newStream({id:t,name:e,type:"initiator",registry:r})}close(e){this.closeController.signal.aborted||(e!=null?this.streams.forEach(t=>t.abort(e)):this.streams.forEach(t=>t.close()),this.closeController.abort())}_newReceiverStream(e){let{id:t,name:r}=e,n=this._streams.receivers;return this._newStream({id:t,name:r,type:"receiver",registry:n})}_newStream(e){let{id:t,name:r,type:n,registry:s}=e;if(O("new %s stream %s",n,t),n==="initiator"&&this._streams.initiators.size===(this._init.maxOutboundStreams??io))throw(0,At.default)(new Error("Too many outbound streams open"),"ERR_TOO_MANY_OUTBOUND_STREAMS");if(s.has(t))throw new Error(`${n} stream ${t} already exists!`);let c=Tr({id:t,name:r,send:l=>{O.enabled&&O.trace("%s stream %s send",n,t,Ci(l)),this._source.push(l)},type:n,onEnd:()=>{O("%s stream with id %s and protocol %s ended",n,t,c.stat.protocol),s.delete(t),this._init.onStreamEnd!=null&&this._init.onStreamEnd(c)},maxMsgSize:this._init.maxMsgSize});return s.set(t,c),c}_createSink(){return async t=>{let r=[this.closeController.signal];this._init.signal!=null&&r.push(this._init.signal),t=we(t,(0,Ai.default)(r));try{let n=new xe(this._init.maxMsgSize,this._init.maxUnprocessedMessageQueueSize);for await(let s of t)for(let o of n.write(s))await this._handleIncoming(o);this._source.end()}catch(n){O("error in sink",n),this._source.end(n)}}}_createSource(){let t=Mt({objectMode:!0,onEnd:r=>{this.close(r)}});return Object.assign(Yt(t,this._init.minSendBytes),{push:t.push,end:t.end,return:t.return})}async _handleIncoming(e){let{id:t,type:r}=e;if(O.enabled&&O.trace("incoming message",Ci(e)),e.type===w.NEW_STREAM){if(this._streams.receivers.size===(this._init.maxInboundStreams??ro)){O("too many inbound streams open"),this._source.push({id:t,type:w.RESET_RECEIVER});try{await this.rateLimiter.consume("new-stream",1)}catch{O("rate limit hit when opening too many new streams over the inbound stream limit - closing remote connection"),this._source.end(new Error("Too many open streams"));return}return}let a=this._newReceiverStream({id:t,name:de(e.data instanceof Uint8Array?e.data:e.data.subarray())});this._init.onIncomingStream!=null&&this._init.onIncomingStream(a);return}let s=((r&1)===1?this._streams.initiators:this._streams.receivers).get(t);if(s==null){O("missing stream %s for message type %s",t,ce[r]);return}let o=this._init.maxStreamBufferSize??no;switch(r){case w.MESSAGE_INITIATOR:case w.MESSAGE_RECEIVER:if(s.sourceReadableLength()>o){this._source.push({id:e.id,type:r===w.MESSAGE_INITIATOR?w.RESET_RECEIVER:w.RESET_INITIATOR});let a=(0,At.default)(new Error("Input buffer full - increase Mplex maxBufferSize to accommodate slow consumers"),"ERR_STREAM_INPUT_BUFFER_FULL");s.abort(a);return}s.sourcePush(e.data);break;case w.CLOSE_INITIATOR:case w.CLOSE_RECEIVER:s.closeRead();break;case w.RESET_INITIATOR:case w.RESET_RECEIVER:s.reset();break;default:O("unknown message type %s",r)}}};var Tt=class{constructor(e={}){this.protocol="/mplex/6.7.0",this._init=e}createStreamMuxer(e={}){return new Me({...e,...this._init})}};function oo(i={}){return()=>new Tt(i)}return ki(ao);})();
|
25
|
+
return Libp2PMplex}));
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@libp2p/mplex",
|
3
|
-
"version": "7.1.
|
3
|
+
"version": "7.1.1",
|
4
4
|
"description": "JavaScript implementation of https://github.com/libp2p/mplex",
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p-mplex#readme",
|
@@ -29,7 +29,7 @@
|
|
29
29
|
"types": "./dist/src/index.d.ts",
|
30
30
|
"files": [
|
31
31
|
"src",
|
32
|
-
"dist
|
32
|
+
"dist",
|
33
33
|
"!dist/test",
|
34
34
|
"!**/*.tsbuildinfo"
|
35
35
|
],
|
@@ -143,7 +143,8 @@
|
|
143
143
|
"test:firefox-webworker": "aegir test -t webworker -- --browser firefox",
|
144
144
|
"test:node": "aegir test -t node --cov",
|
145
145
|
"test:electron-main": "aegir test -t electron-main",
|
146
|
-
"release": "aegir release"
|
146
|
+
"release": "aegir release",
|
147
|
+
"docs": "aegir docs"
|
147
148
|
},
|
148
149
|
"dependencies": {
|
149
150
|
"@libp2p/interface-connection": "^3.0.1",
|