@libp2p/utils 6.7.2-8484de8a2 → 6.7.2-87bc8d4fb

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.
Files changed (164) hide show
  1. package/README.md +1 -1
  2. package/dist/index.min.js +1 -6
  3. package/dist/index.min.js.map +4 -4
  4. package/dist/src/abort-options.d.ts +7 -0
  5. package/dist/src/abort-options.d.ts.map +1 -0
  6. package/dist/src/abort-options.js +14 -0
  7. package/dist/src/abort-options.js.map +1 -0
  8. package/dist/src/abstract-stream.d.ts +130 -14
  9. package/dist/src/abstract-stream.d.ts.map +1 -1
  10. package/dist/src/abstract-stream.js +321 -39
  11. package/dist/src/abstract-stream.js.map +1 -1
  12. package/dist/src/array-equals.d.ts +24 -0
  13. package/dist/src/array-equals.d.ts.map +1 -0
  14. package/dist/src/array-equals.js +31 -0
  15. package/dist/src/array-equals.js.map +1 -0
  16. package/dist/src/close-source.d.ts +4 -0
  17. package/dist/src/close-source.d.ts.map +1 -0
  18. package/dist/src/close-source.js +11 -0
  19. package/dist/src/close-source.js.map +1 -0
  20. package/dist/src/close.d.ts +21 -0
  21. package/dist/src/close.d.ts.map +1 -0
  22. package/dist/src/close.js +49 -0
  23. package/dist/src/close.js.map +1 -0
  24. package/dist/src/errors.d.ts +0 -8
  25. package/dist/src/errors.d.ts.map +1 -1
  26. package/dist/src/errors.js +0 -8
  27. package/dist/src/errors.js.map +1 -1
  28. package/dist/src/get-thin-waist-addresses.browser.d.ts +1 -1
  29. package/dist/src/get-thin-waist-addresses.browser.d.ts.map +1 -1
  30. package/dist/src/get-thin-waist-addresses.browser.js +3 -4
  31. package/dist/src/get-thin-waist-addresses.browser.js.map +1 -1
  32. package/dist/src/get-thin-waist-addresses.d.ts +1 -1
  33. package/dist/src/get-thin-waist-addresses.d.ts.map +1 -1
  34. package/dist/src/get-thin-waist-addresses.js +9 -7
  35. package/dist/src/get-thin-waist-addresses.js.map +1 -1
  36. package/dist/src/index.d.ts +1 -33
  37. package/dist/src/index.d.ts.map +1 -1
  38. package/dist/src/index.js +1 -33
  39. package/dist/src/index.js.map +1 -1
  40. package/dist/src/multiaddr/is-global-unicast.d.ts.map +1 -1
  41. package/dist/src/multiaddr/is-global-unicast.js +9 -8
  42. package/dist/src/multiaddr/is-global-unicast.js.map +1 -1
  43. package/dist/src/multiaddr/is-ip-based.d.ts +6 -0
  44. package/dist/src/multiaddr/is-ip-based.d.ts.map +1 -0
  45. package/dist/src/multiaddr/is-ip-based.js +18 -0
  46. package/dist/src/multiaddr/is-ip-based.js.map +1 -0
  47. package/dist/src/multiaddr/is-link-local.d.ts.map +1 -1
  48. package/dist/src/multiaddr/is-link-local.js +16 -11
  49. package/dist/src/multiaddr/is-link-local.js.map +1 -1
  50. package/dist/src/multiaddr/is-loopback.d.ts.map +1 -1
  51. package/dist/src/multiaddr/is-loopback.js +5 -12
  52. package/dist/src/multiaddr/is-loopback.js.map +1 -1
  53. package/dist/src/multiaddr/is-network-address.d.ts.map +1 -1
  54. package/dist/src/multiaddr/is-network-address.js +16 -4
  55. package/dist/src/multiaddr/is-network-address.js.map +1 -1
  56. package/dist/src/multiaddr/is-private.d.ts.map +1 -1
  57. package/dist/src/multiaddr/is-private.js +10 -9
  58. package/dist/src/multiaddr/is-private.js.map +1 -1
  59. package/dist/src/queue/index.d.ts +0 -3
  60. package/dist/src/queue/index.d.ts.map +1 -1
  61. package/dist/src/queue/index.js +4 -20
  62. package/dist/src/queue/index.js.map +1 -1
  63. package/dist/src/rate-limiter.d.ts +15 -1
  64. package/dist/src/rate-limiter.d.ts.map +1 -1
  65. package/dist/src/rate-limiter.js +14 -1
  66. package/dist/src/rate-limiter.js.map +1 -1
  67. package/dist/src/stream-to-ma-conn.d.ts +23 -0
  68. package/dist/src/stream-to-ma-conn.d.ts.map +1 -0
  69. package/dist/src/stream-to-ma-conn.js +75 -0
  70. package/dist/src/stream-to-ma-conn.js.map +1 -0
  71. package/package.json +163 -19
  72. package/src/abort-options.ts +20 -0
  73. package/src/abstract-stream.ts +464 -51
  74. package/src/array-equals.ts +34 -0
  75. package/src/close-source.ts +14 -0
  76. package/src/close.ts +65 -0
  77. package/src/errors.ts +0 -10
  78. package/src/get-thin-waist-addresses.browser.ts +4 -5
  79. package/src/get-thin-waist-addresses.ts +12 -8
  80. package/src/index.ts +1 -33
  81. package/src/multiaddr/is-global-unicast.ts +11 -8
  82. package/src/multiaddr/is-ip-based.ts +21 -0
  83. package/src/multiaddr/is-link-local.ts +20 -11
  84. package/src/multiaddr/is-loopback.ts +7 -12
  85. package/src/multiaddr/is-network-address.ts +19 -4
  86. package/src/multiaddr/is-private.ts +14 -9
  87. package/src/queue/index.ts +4 -24
  88. package/src/rate-limiter.ts +30 -3
  89. package/src/stream-to-ma-conn.ts +106 -0
  90. package/dist/src/abstract-message-stream.d.ts +0 -129
  91. package/dist/src/abstract-message-stream.d.ts.map +0 -1
  92. package/dist/src/abstract-message-stream.js +0 -389
  93. package/dist/src/abstract-message-stream.js.map +0 -1
  94. package/dist/src/abstract-multiaddr-connection.d.ts +0 -26
  95. package/dist/src/abstract-multiaddr-connection.d.ts.map +0 -1
  96. package/dist/src/abstract-multiaddr-connection.js +0 -66
  97. package/dist/src/abstract-multiaddr-connection.js.map +0 -1
  98. package/dist/src/abstract-stream-muxer.d.ts +0 -53
  99. package/dist/src/abstract-stream-muxer.d.ts.map +0 -1
  100. package/dist/src/abstract-stream-muxer.js +0 -169
  101. package/dist/src/abstract-stream-muxer.js.map +0 -1
  102. package/dist/src/length-prefixed-decoder.d.ts +0 -37
  103. package/dist/src/length-prefixed-decoder.d.ts.map +0 -1
  104. package/dist/src/length-prefixed-decoder.js +0 -64
  105. package/dist/src/length-prefixed-decoder.js.map +0 -1
  106. package/dist/src/message-queue.d.ts +0 -61
  107. package/dist/src/message-queue.d.ts.map +0 -1
  108. package/dist/src/message-queue.js +0 -93
  109. package/dist/src/message-queue.js.map +0 -1
  110. package/dist/src/mock-muxer.d.ts +0 -57
  111. package/dist/src/mock-muxer.d.ts.map +0 -1
  112. package/dist/src/mock-muxer.js +0 -204
  113. package/dist/src/mock-muxer.js.map +0 -1
  114. package/dist/src/mock-stream.d.ts +0 -31
  115. package/dist/src/mock-stream.d.ts.map +0 -1
  116. package/dist/src/mock-stream.js +0 -69
  117. package/dist/src/mock-stream.js.map +0 -1
  118. package/dist/src/multiaddr/get-net-config.d.ts +0 -55
  119. package/dist/src/multiaddr/get-net-config.d.ts.map +0 -1
  120. package/dist/src/multiaddr/get-net-config.js +0 -54
  121. package/dist/src/multiaddr/get-net-config.js.map +0 -1
  122. package/dist/src/multiaddr/index.d.ts +0 -7
  123. package/dist/src/multiaddr/index.d.ts.map +0 -1
  124. package/dist/src/multiaddr/index.js +0 -7
  125. package/dist/src/multiaddr/index.js.map +0 -1
  126. package/dist/src/multiaddr/utils.d.ts +0 -5
  127. package/dist/src/multiaddr/utils.d.ts.map +0 -1
  128. package/dist/src/multiaddr/utils.js +0 -32
  129. package/dist/src/multiaddr/utils.js.map +0 -1
  130. package/dist/src/multiaddr-connection-pair.d.ts +0 -25
  131. package/dist/src/multiaddr-connection-pair.d.ts.map +0 -1
  132. package/dist/src/multiaddr-connection-pair.js +0 -103
  133. package/dist/src/multiaddr-connection-pair.js.map +0 -1
  134. package/dist/src/socket-writer.browser.d.ts +0 -2
  135. package/dist/src/socket-writer.browser.d.ts.map +0 -1
  136. package/dist/src/socket-writer.browser.js +0 -4
  137. package/dist/src/socket-writer.browser.js.map +0 -1
  138. package/dist/src/socket-writer.d.ts +0 -19
  139. package/dist/src/socket-writer.d.ts.map +0 -1
  140. package/dist/src/socket-writer.js +0 -43
  141. package/dist/src/socket-writer.js.map +0 -1
  142. package/dist/src/stream-pair.d.ts +0 -42
  143. package/dist/src/stream-pair.d.ts.map +0 -1
  144. package/dist/src/stream-pair.js +0 -40
  145. package/dist/src/stream-pair.js.map +0 -1
  146. package/dist/src/stream-utils.d.ts +0 -198
  147. package/dist/src/stream-utils.d.ts.map +0 -1
  148. package/dist/src/stream-utils.js +0 -369
  149. package/dist/src/stream-utils.js.map +0 -1
  150. package/src/abstract-message-stream.ts +0 -549
  151. package/src/abstract-multiaddr-connection.ts +0 -93
  152. package/src/abstract-stream-muxer.ts +0 -239
  153. package/src/length-prefixed-decoder.ts +0 -98
  154. package/src/message-queue.ts +0 -156
  155. package/src/mock-muxer.ts +0 -304
  156. package/src/mock-stream.ts +0 -101
  157. package/src/multiaddr/get-net-config.ts +0 -112
  158. package/src/multiaddr/index.ts +0 -6
  159. package/src/multiaddr/utils.ts +0 -46
  160. package/src/multiaddr-connection-pair.ts +0 -147
  161. package/src/socket-writer.browser.ts +0 -3
  162. package/src/socket-writer.ts +0 -64
  163. package/src/stream-pair.ts +0 -90
  164. package/src/stream-utils.ts +0 -873
@@ -1,53 +0,0 @@
1
- import { TypedEventEmitter } from '@libp2p/interface';
2
- import type { AbstractStream } from './abstract-stream.ts';
3
- import type { AbortOptions, CounterGroup, CreateStreamOptions, EventHandler, Logger, MessageStream, StreamMuxer, StreamMuxerEvents, StreamMuxerOptions, StreamMuxerStatus, StreamOptions } from '@libp2p/interface';
4
- import type { Uint8ArrayList } from 'uint8arraylist';
5
- export interface AbstractStreamMuxerInit extends StreamMuxerOptions {
6
- /**
7
- * The protocol name for the muxer
8
- */
9
- protocol: string;
10
- /**
11
- * The name of the muxer, used to create a new logging scope from the passed
12
- * connection's logger
13
- */
14
- name: string;
15
- /**
16
- * A counter for muxer metrics
17
- */
18
- metrics?: CounterGroup;
19
- }
20
- export declare abstract class AbstractStreamMuxer<MuxedStream extends AbstractStream = AbstractStream> extends TypedEventEmitter<StreamMuxerEvents<MuxedStream>> implements StreamMuxer<MuxedStream> {
21
- streams: MuxedStream[];
22
- protocol: string;
23
- status: StreamMuxerStatus;
24
- protected log: Logger;
25
- protected maConn: MessageStream;
26
- protected streamOptions?: StreamOptions;
27
- protected earlyStreams: MuxedStream[];
28
- protected maxEarlyStreams: number;
29
- private readonly metrics?;
30
- constructor(maConn: MessageStream, init: AbstractStreamMuxerInit);
31
- send(data: Uint8Array | Uint8ArrayList): boolean;
32
- close(options?: AbortOptions): Promise<void>;
33
- abort(err: Error): void;
34
- onTransportClosed(err?: Error): void;
35
- createStream(options?: CreateStreamOptions): Promise<MuxedStream>;
36
- /**
37
- * Extending classes should invoke this method when a new stream was created
38
- * by the remote muxer
39
- */
40
- onRemoteStream(stream: MuxedStream): void;
41
- private cleanUpStream;
42
- addEventListener<K extends keyof StreamMuxerEvents<MuxedStream>>(type: K, listener: EventHandler<StreamMuxerEvents<MuxedStream>[K]> | null, options?: boolean | AddEventListenerOptions): void;
43
- addEventListener(type: string, listener: EventHandler<Event>, options?: boolean | AddEventListenerOptions): void;
44
- /**
45
- * A new outgoing stream needs to be created
46
- */
47
- abstract onCreateStream(options: CreateStreamOptions): MuxedStream | Promise<MuxedStream>;
48
- /**
49
- * Multiplexed data was received from the remote muxer
50
- */
51
- abstract onData(data: Uint8Array | Uint8ArrayList): void;
52
- }
53
- //# sourceMappingURL=abstract-stream-muxer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"abstract-stream-muxer.d.ts","sourceRoot":"","sources":["../../src/abstract-stream-muxer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;AAIvE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAgD,WAAW,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjQ,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAEpD,MAAM,WAAW,uBAAwB,SAAQ,kBAAkB;IACjE;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAA;IAEhB;;;OAGG;IACH,IAAI,EAAE,MAAM,CAAA;IAEZ;;OAEG;IACH,OAAO,CAAC,EAAE,YAAY,CAAA;CACvB;AAED,8BAAsB,mBAAmB,CAAE,WAAW,SAAS,cAAc,GAAG,cAAc,CAAE,SAAQ,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAE,YAAW,WAAW,CAAC,WAAW,CAAC;IACpL,OAAO,EAAE,WAAW,EAAE,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,EAAE,iBAAiB,CAAA;IAEhC,SAAS,CAAC,GAAG,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,MAAM,EAAE,aAAa,CAAA;IAC/B,SAAS,CAAC,aAAa,CAAC,EAAE,aAAa,CAAA;IACvC,SAAS,CAAC,YAAY,EAAE,WAAW,EAAE,CAAA;IACrC,SAAS,CAAC,eAAe,EAAE,MAAM,CAAA;IAEjC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAc;gBAE1B,MAAM,EAAE,aAAa,EAAE,IAAI,EAAE,uBAAuB;IAyCjE,IAAI,CAAE,IAAI,EAAE,UAAU,GAAG,cAAc,GAAG,OAAO;IAc3C,KAAK,CAAE,OAAO,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBnD,KAAK,CAAE,GAAG,EAAE,KAAK,GAAG,IAAI;IAcxB,iBAAiB,CAAE,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI;IAc/B,YAAY,CAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,OAAO,CAAC,WAAW,CAAC;IAoBxE;;;OAGG;IACH,cAAc,CAAE,MAAM,EAAE,WAAW,GAAG,IAAI;IAqB1C,OAAO,CAAC,aAAa;IAuBrB,gBAAgB,CAAC,CAAC,SAAS,MAAM,iBAAiB,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,uBAAuB,GAAG,IAAI;IAC9L,gBAAgB,CAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,uBAAuB,GAAG,IAAI;IAsBjH;;OAEG;IACH,QAAQ,CAAC,cAAc,CAAE,OAAO,EAAE,mBAAmB,GAAG,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;IAE1F;;OAEG;IACH,QAAQ,CAAC,MAAM,CAAE,IAAI,EAAE,UAAU,GAAG,cAAc,GAAG,IAAI;CAC1D"}
@@ -1,169 +0,0 @@
1
- import { MuxerClosedError, TypedEventEmitter } from '@libp2p/interface';
2
- import { raceSignal } from 'race-signal';
3
- import { MaxEarlyStreamsError } from "./errors.js";
4
- import { isPromise } from "./is-promise.js";
5
- export class AbstractStreamMuxer extends TypedEventEmitter {
6
- streams;
7
- protocol;
8
- status;
9
- log;
10
- maConn;
11
- streamOptions;
12
- earlyStreams;
13
- maxEarlyStreams;
14
- metrics;
15
- constructor(maConn, init) {
16
- super();
17
- this.maConn = maConn;
18
- this.protocol = init.protocol;
19
- this.streams = [];
20
- this.earlyStreams = [];
21
- this.status = 'open';
22
- this.log = maConn.log.newScope(init.name);
23
- this.streamOptions = init.streamOptions;
24
- this.maxEarlyStreams = init.maxEarlyStreams ?? 10;
25
- this.metrics = init.metrics;
26
- // read/write all data from/to underlying maConn
27
- const muxerMaConnOnMessage = (evt) => {
28
- try {
29
- this.onData(evt.data);
30
- }
31
- catch (err) {
32
- this.abort(err);
33
- this.maConn.abort(err);
34
- }
35
- };
36
- this.maConn.addEventListener('message', muxerMaConnOnMessage);
37
- // signal stream writers when the underlying connection can accept more data
38
- const muxerMaConnOnDrain = () => {
39
- this.log('underlying stream drained, signal %d streams to continue writing', this.streams.length);
40
- this.streams.forEach(stream => {
41
- stream.onMuxerDrain();
42
- });
43
- };
44
- this.maConn.addEventListener('drain', muxerMaConnOnDrain);
45
- const muxerOnMaConnClose = () => {
46
- this.log('underlying stream closed with status %s and %d streams', this.status, this.streams.length);
47
- this.onTransportClosed();
48
- };
49
- this.maConn.addEventListener('close', muxerOnMaConnClose);
50
- }
51
- send(data) {
52
- const result = this.maConn.send(data);
53
- if (result === false) {
54
- this.log('underlying stream saturated, signal %d streams to pause writing', this.streams.length);
55
- this.streams.forEach(stream => {
56
- stream.onMuxerNeedsDrain();
57
- });
58
- }
59
- return result;
60
- }
61
- async close(options) {
62
- if (this.status === 'closed' || this.status === 'closing') {
63
- return;
64
- }
65
- this.status = 'closing';
66
- await raceSignal(Promise.all([...this.streams].map(async (s) => {
67
- await s.close(options);
68
- })), options?.signal);
69
- this.status = 'closed';
70
- }
71
- abort(err) {
72
- if (this.status === 'closed') {
73
- return;
74
- }
75
- this.status = 'closing';
76
- [...this.streams].forEach(s => {
77
- s.abort(err);
78
- });
79
- this.status = 'closed';
80
- }
81
- onTransportClosed(err) {
82
- this.status = 'closing';
83
- try {
84
- [...this.streams].forEach(stream => {
85
- stream.onTransportClosed(err);
86
- });
87
- }
88
- catch (err) {
89
- this.abort(err);
90
- }
91
- this.status = 'closed';
92
- }
93
- async createStream(options) {
94
- if (this.status !== 'open') {
95
- throw new MuxerClosedError();
96
- }
97
- let stream = this.onCreateStream({
98
- ...this.streamOptions,
99
- ...options
100
- });
101
- if (isPromise(stream)) {
102
- stream = await stream;
103
- }
104
- this.streams.push(stream);
105
- this.cleanUpStream(stream);
106
- return stream;
107
- }
108
- /**
109
- * Extending classes should invoke this method when a new stream was created
110
- * by the remote muxer
111
- */
112
- onRemoteStream(stream) {
113
- this.streams.push(stream);
114
- this.cleanUpStream(stream);
115
- if (this.listenerCount('stream') === 0) {
116
- // no listener has been added for the stream event yet, store the stream
117
- // to emit it later
118
- this.earlyStreams.push(stream);
119
- if (this.earlyStreams.length > this.maxEarlyStreams) {
120
- this.abort(new MaxEarlyStreamsError(`Too many early streams were opened - ${this.earlyStreams.length}/${this.maxEarlyStreams}`));
121
- }
122
- return;
123
- }
124
- this.safeDispatchEvent('stream', {
125
- detail: stream
126
- });
127
- }
128
- cleanUpStream(stream) {
129
- const muxerOnStreamEnd = (evt) => {
130
- const index = this.streams.findIndex(s => s === stream);
131
- if (index !== -1) {
132
- this.streams.splice(index, 1);
133
- }
134
- if (evt.error != null) {
135
- if (evt.local) {
136
- this.metrics?.increment({ [`${stream.direction}_stream_reset`]: true });
137
- }
138
- else {
139
- this.metrics?.increment({ [`${stream.direction}_stream_abort`]: true });
140
- }
141
- }
142
- else {
143
- this.metrics?.increment({ [`${stream.direction}_stream_end`]: true });
144
- }
145
- };
146
- stream.addEventListener('close', muxerOnStreamEnd);
147
- this.metrics?.increment({ [`${stream.direction}_stream`]: true });
148
- }
149
- addEventListener(...args) {
150
- // @ts-expect-error cannot ensure args has enough members
151
- super.addEventListener.apply(this, args);
152
- // if a 'stream' listener is being added and we have early streams, emit
153
- // them
154
- if (args[0] === 'stream' && this.earlyStreams.length > 0) {
155
- // event listeners can be added in constructors and often use object
156
- // properties - if this the case we can access a class member before it
157
- // has been initialized so dispatch the message in the microtask queue
158
- queueMicrotask(() => {
159
- this.earlyStreams.forEach(stream => {
160
- this.safeDispatchEvent('stream', {
161
- detail: stream
162
- });
163
- });
164
- this.earlyStreams = [];
165
- });
166
- }
167
- }
168
- }
169
- //# sourceMappingURL=abstract-stream-muxer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"abstract-stream-muxer.js","sourceRoot":"","sources":["../../src/abstract-stream-muxer.ts"],"names":[],"mappings":"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"}
@@ -1,37 +0,0 @@
1
- import { Uint8ArrayList } from 'uint8arraylist';
2
- export interface LengthPrefixedDecoderInit {
3
- /**
4
- * How large the internal buffer is allowed to grow - attempting to store more
5
- * data than this will throw
6
- */
7
- maxBufferSize?: number;
8
- /**
9
- * Throw an error if the message that would be read from the buffer is larger
10
- * than this value
11
- */
12
- maxDataLength?: number;
13
- /**
14
- * Read a varint from the buffer
15
- */
16
- lengthDecoder?(data: Uint8ArrayList | Uint8Array): number;
17
- /**
18
- * Return how many bytes it takes to encode the passed value
19
- */
20
- encodingLength?(length: number): number;
21
- }
22
- /**
23
- * Decode length-prefixed data from a buffer
24
- */
25
- export declare class LengthPrefixedDecoder {
26
- private readonly buffer;
27
- private readonly maxBufferSize;
28
- private readonly lengthDecoder;
29
- private readonly maxDataLength;
30
- private readonly encodingLength;
31
- constructor(init?: LengthPrefixedDecoderInit);
32
- /**
33
- * Decodes length-prefixed data
34
- */
35
- decode(buf: Uint8Array | Uint8ArrayList): Generator<Uint8ArrayList>;
36
- }
37
- //# sourceMappingURL=length-prefixed-decoder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"length-prefixed-decoder.d.ts","sourceRoot":"","sources":["../../src/length-prefixed-decoder.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAM/C,MAAM,WAAW,yBAAyB;IACxC;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAA;IAEtB;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAA;IAEtB;;OAEG;IACH,aAAa,CAAC,CAAC,IAAI,EAAE,cAAc,GAAG,UAAU,GAAG,MAAM,CAAA;IAEzD;;OAEG;IACH,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAA;CACxC;AAED;;GAEG;AACH,qBAAa,qBAAqB;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;IACvC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAQ;IACtC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAA+C;IAC7E,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAQ;IACtC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA4B;gBAE9C,IAAI,GAAE,yBAA8B;IAQjD;;OAEG;IACD,MAAM,CAAE,GAAG,EAAE,UAAU,GAAG,cAAc,GAAG,SAAS,CAAC,cAAc,CAAC;CA4CvE"}
@@ -1,64 +0,0 @@
1
- import { InvalidParametersError } from '@libp2p/interface';
2
- import * as varint from 'uint8-varint';
3
- import { Uint8ArrayList } from 'uint8arraylist';
4
- import { InvalidMessageLengthError } from "./stream-utils.js";
5
- const DEFAULT_MAX_BUFFER_SIZE = 1024 * 1024 * 4;
6
- const DEFAULT_MAX_DATA_LENGTH = 1024 * 1024 * 4;
7
- /**
8
- * Decode length-prefixed data from a buffer
9
- */
10
- export class LengthPrefixedDecoder {
11
- buffer;
12
- maxBufferSize;
13
- lengthDecoder;
14
- maxDataLength;
15
- encodingLength;
16
- constructor(init = {}) {
17
- this.buffer = new Uint8ArrayList();
18
- this.maxBufferSize = init.maxBufferSize ?? DEFAULT_MAX_BUFFER_SIZE;
19
- this.maxDataLength = init.maxDataLength ?? DEFAULT_MAX_DATA_LENGTH;
20
- this.lengthDecoder = init.lengthDecoder ?? varint.decode;
21
- this.encodingLength = init.encodingLength ?? varint.encodingLength;
22
- }
23
- /**
24
- * Decodes length-prefixed data
25
- */
26
- *decode(buf) {
27
- this.buffer.append(buf);
28
- if (this.buffer.byteLength > this.maxBufferSize) {
29
- throw new InvalidParametersError(`Buffer length limit exceeded - ${this.buffer.byteLength}/${this.maxBufferSize}`);
30
- }
31
- // Loop to consume as many bytes from the buffer as possible
32
- // Eg: when a single chunk contains several frames
33
- while (true) {
34
- let dataLength;
35
- try {
36
- dataLength = this.lengthDecoder(this.buffer);
37
- }
38
- catch (err) {
39
- if (err instanceof RangeError) {
40
- // ignore errors where we don't have enough data to read the length
41
- // prefix
42
- break;
43
- }
44
- throw err;
45
- }
46
- if (dataLength < 0 || dataLength > this.maxDataLength) {
47
- throw new InvalidMessageLengthError('Invalid message length');
48
- }
49
- const lengthLength = this.encodingLength(dataLength);
50
- const chunkLength = lengthLength + dataLength;
51
- if (this.buffer.byteLength >= chunkLength) {
52
- const buf = this.buffer.sublist(lengthLength, chunkLength);
53
- this.buffer.consume(chunkLength);
54
- if (buf.byteLength > 0) {
55
- yield buf;
56
- }
57
- }
58
- else {
59
- break;
60
- }
61
- }
62
- }
63
- }
64
- //# sourceMappingURL=length-prefixed-decoder.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"length-prefixed-decoder.js","sourceRoot":"","sources":["../../src/length-prefixed-decoder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,KAAK,MAAM,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAA;AAE7D,MAAM,uBAAuB,GAAG,IAAI,GAAG,IAAI,GAAG,CAAC,CAAA;AAC/C,MAAM,uBAAuB,GAAG,IAAI,GAAG,IAAI,GAAG,CAAC,CAAA;AA0B/C;;GAEG;AACH,MAAM,OAAO,qBAAqB;IACf,MAAM,CAAgB;IACtB,aAAa,CAAQ;IACrB,aAAa,CAA+C;IAC5D,aAAa,CAAQ;IACrB,cAAc,CAA4B;IAE3D,YAAa,OAAkC,EAAE;QAC/C,IAAI,CAAC,MAAM,GAAG,IAAI,cAAc,EAAE,CAAA;QAClC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,uBAAuB,CAAA;QAClE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,uBAAuB,CAAA;QAClE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,MAAM,CAAA;QACxD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAA;IACpE,CAAC;IAED;;OAEG;IACH,CAAE,MAAM,CAAE,GAAgC;QACxC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QAEvB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YAChD,MAAM,IAAI,sBAAsB,CAAC,kCAAkC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,CAAA;QACpH,CAAC;QAED,4DAA4D;QAC5D,kDAAkD;QAClD,OAAO,IAAI,EAAE,CAAC;YACZ,IAAI,UAAkB,CAAA;YAEtB,IAAI,CAAC;gBACH,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YAC9C,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,GAAG,YAAY,UAAU,EAAE,CAAC;oBAC9B,mEAAmE;oBACnE,SAAS;oBACT,MAAK;gBACP,CAAC;gBAED,MAAM,GAAG,CAAA;YACX,CAAC;YAED,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtD,MAAM,IAAI,yBAAyB,CAAC,wBAAwB,CAAC,CAAA;YAC/D,CAAC;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,CAAA;YACpD,MAAM,WAAW,GAAG,YAAY,GAAG,UAAU,CAAA;YAE7C,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,WAAW,EAAE,CAAC;gBAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;gBAE1D,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;gBAEhC,IAAI,GAAG,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;oBACvB,MAAM,GAAG,CAAA;gBACX,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAK;YACP,CAAC;QACH,CAAC;IACH,CAAC;CACF"}
@@ -1,61 +0,0 @@
1
- import { StreamMessageEvent } from '@libp2p/interface';
2
- import { TypedEventEmitter } from 'main-event';
3
- import type { Logger } from '@libp2p/interface';
4
- export interface MessageQueueEvents {
5
- /**
6
- * Message data
7
- */
8
- message: StreamMessageEvent;
9
- /**
10
- * Emitted when the queue is empty
11
- */
12
- drain: Event;
13
- /**
14
- * The remote closed the connection abruptly
15
- */
16
- reset: Event;
17
- }
18
- export interface MessageQueueInit {
19
- /**
20
- * How much delay there should be between each message send in ms (note that
21
- * even 0 introduces a small delay)
22
- *
23
- * @default 0
24
- */
25
- delay?: number;
26
- /**
27
- * How many messages to hold in the send queue before applying backpressure to
28
- * the sender
29
- */
30
- capacity?: number;
31
- /**
32
- * Data messages larger than this size will be chunked into smaller messages.
33
- *
34
- * Defaults to the maximum TCP package size.
35
- *
36
- * @default 65_536
37
- */
38
- chunkSize?: number;
39
- }
40
- /**
41
- * Accepts events to emit after a short delay, and with a configurable maximum
42
- * queue capacity after which the send method will return false to let us
43
- * simulate write backpressure.
44
- */
45
- export declare class MessageQueue<Events> extends TypedEventEmitter<Events & MessageQueueEvents> {
46
- needsDrain: boolean;
47
- private queue;
48
- private capacity;
49
- private delay;
50
- private log;
51
- private chunkSize;
52
- constructor(init: MessageQueueInit & {
53
- log: Logger;
54
- });
55
- send(evt: Event): boolean;
56
- pause(): void;
57
- resume(): void;
58
- onIdle(): Promise<void>;
59
- size(): number;
60
- }
61
- //# sourceMappingURL=message-queue.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"message-queue.d.ts","sourceRoot":"","sources":["../../src/message-queue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAEtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAI9C,OAAO,KAAK,EAAgB,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAI7D,MAAM,WAAW,kBAAkB;IACjC;;OAEG;IACH,OAAO,EAAE,kBAAkB,CAAA;IAE3B;;OAEG;IACH,KAAK,EAAE,KAAK,CAAA;IAEZ;;OAEG;IACH,KAAK,EAAE,KAAK,CAAA;CACb;AAED,MAAM,WAAW,gBAAgB;IAC/B;;;;;OAKG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IAEd;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAA;IAEjB;;;;;;OAMG;IACH,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAMD;;;;GAIG;AACH,qBAAa,YAAY,CAAC,MAAM,CAAE,SAAQ,iBAAiB,CAAC,MAAM,GAAG,kBAAkB,CAAC;IAC/E,UAAU,EAAE,OAAO,CAAA;IAE1B,OAAO,CAAC,KAAK,CAAqC;IAClD,OAAO,CAAC,QAAQ,CAAQ;IACxB,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,GAAG,CAAQ;IACnB,OAAO,CAAC,SAAS,CAAQ;gBAEZ,IAAI,EAAE,gBAAgB,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE;IAuBrD,IAAI,CAAE,GAAG,EAAE,KAAK,GAAG,OAAO;IA2C1B,KAAK,IAAK,IAAI;IAId,MAAM,IAAK,IAAI;IAIf,MAAM,IAAK,OAAO,CAAC,IAAI,CAAC;IAIxB,IAAI,IAAK,MAAM;CAGhB"}
@@ -1,93 +0,0 @@
1
- import { StreamMessageEvent } from '@libp2p/interface';
2
- import delay from 'delay';
3
- import { TypedEventEmitter } from 'main-event';
4
- import { raceSignal } from 'race-signal';
5
- import { isUint8ArrayList, Uint8ArrayList } from 'uint8arraylist';
6
- import { Queue } from './queue/index.js';
7
- const DEFAULT_CHUNK_SIZE = 1024 * 64;
8
- /**
9
- * Accepts events to emit after a short delay, and with a configurable maximum
10
- * queue capacity after which the send method will return false to let us
11
- * simulate write backpressure.
12
- */
13
- export class MessageQueue extends TypedEventEmitter {
14
- needsDrain;
15
- queue;
16
- capacity;
17
- delay;
18
- log;
19
- chunkSize;
20
- constructor(init) {
21
- super();
22
- this.needsDrain = false;
23
- this.queue = new Queue({
24
- concurrency: 1
25
- });
26
- this.capacity = init.capacity ?? 5;
27
- this.delay = init.delay ?? 0;
28
- this.log = init.log;
29
- this.chunkSize = init.chunkSize ?? DEFAULT_CHUNK_SIZE;
30
- this.queue.addEventListener('idle', () => {
31
- if (this.needsDrain) {
32
- this.log('network send queue drained');
33
- this.needsDrain = false;
34
- this.safeDispatchEvent('drain');
35
- }
36
- else {
37
- this.log('network send queue idle');
38
- }
39
- });
40
- }
41
- send(evt) {
42
- if (isMessageEvent(evt)) {
43
- // chunk outgoing messages to match TCP packet sizes
44
- const data = new Uint8ArrayList(evt.data);
45
- while (data.byteLength > 0) {
46
- const end = Math.min(this.chunkSize, data.byteLength);
47
- const chunk = data.sublist(0, end);
48
- data.consume(chunk.byteLength);
49
- const chunkEvent = new StreamMessageEvent(chunk);
50
- this.queue.add(async (opts) => {
51
- if (this.delay > 0) {
52
- await raceSignal(delay(this.delay), opts.signal);
53
- }
54
- this.dispatchEvent(opts.evt);
55
- }, {
56
- evt: chunkEvent
57
- });
58
- }
59
- }
60
- else {
61
- this.queue.add(async (opts) => {
62
- if (this.delay > 0) {
63
- await raceSignal(delay(this.delay), opts.signal);
64
- }
65
- this.dispatchEvent(opts.evt);
66
- }, {
67
- evt
68
- });
69
- }
70
- if (this.queue.size >= this.capacity) {
71
- this.log('network send queue full');
72
- this.needsDrain = true;
73
- return false;
74
- }
75
- return true;
76
- }
77
- pause() {
78
- this.queue.pause();
79
- }
80
- resume() {
81
- this.queue.resume();
82
- }
83
- onIdle() {
84
- return this.queue.onIdle();
85
- }
86
- size() {
87
- return this.queue.size;
88
- }
89
- }
90
- function isMessageEvent(evt) {
91
- return evt?.data instanceof Uint8Array || isUint8ArrayList(evt?.data);
92
- }
93
- //# sourceMappingURL=message-queue.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"message-queue.js","sourceRoot":"","sources":["../../src/message-queue.ts"],"names":[],"mappings":"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"}
@@ -1,57 +0,0 @@
1
- import type { AbstractStreamInit } from './abstract-stream.ts';
2
- import type { StreamMuxerFactory, StreamMuxerOptions } from '@libp2p/interface';
3
- import type { SupportedEncodings } from 'uint8arrays/from-string';
4
- interface DataMessage {
5
- id: string;
6
- type: 'data';
7
- chunk: Uint8Array;
8
- }
9
- interface ResetMessage {
10
- id: string;
11
- type: 'reset';
12
- }
13
- interface CloseWriteMessage {
14
- id: string;
15
- type: 'closeWrite';
16
- }
17
- interface CloseReadMessage {
18
- id: string;
19
- type: 'closeRead';
20
- }
21
- interface CreateMessage {
22
- id: string;
23
- type: 'create';
24
- protocol?: string;
25
- }
26
- interface PauseMessage {
27
- id: string;
28
- type: 'pause';
29
- }
30
- interface ResumeMessage {
31
- id: string;
32
- type: 'resume';
33
- }
34
- type StreamMessage = DataMessage | ResetMessage | CloseWriteMessage | CloseReadMessage | CreateMessage | PauseMessage | ResumeMessage;
35
- export interface MockMuxedStreamInit extends AbstractStreamInit {
36
- sendMessage(message: StreamMessage): boolean;
37
- encoding: SupportedEncodings;
38
- }
39
- interface MockMuxerInit extends StreamMuxerOptions {
40
- /**
41
- * How long the input queue can grow
42
- */
43
- maxInputQueueSize?: number;
44
- /**
45
- * How to encode data message
46
- *
47
- * @default base64
48
- */
49
- encoding?: SupportedEncodings;
50
- /**
51
- * How large muxer messages are allowed to be
52
- */
53
- maxMessageSize?: number;
54
- }
55
- export declare function mockMuxer(init?: MockMuxerInit): StreamMuxerFactory;
56
- export {};
57
- //# sourceMappingURL=mock-muxer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mock-muxer.d.ts","sourceRoot":"","sources":["../../src/mock-muxer.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAC9D,OAAO,KAAK,EAA6D,kBAAkB,EAAoC,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAE5K,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAEjE,UAAU,WAAW;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,UAAU,CAAA;CAClB;AAED,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,OAAO,CAAA;CACd;AAED,UAAU,iBAAiB;IACzB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,YAAY,CAAA;CACnB;AAED,UAAU,gBAAgB;IACxB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,WAAW,CAAA;CAClB;AAED,UAAU,aAAa;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,QAAQ,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,OAAO,CAAA;CACd;AAED,UAAU,aAAa;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,QAAQ,CAAA;CACf;AAED,KAAK,aAAa,GAAG,WAAW,GAAG,YAAY,GAAG,iBAAiB,GAAG,gBAAgB,GAAG,aAAa,GAAG,YAAY,GAAG,aAAa,CAAA;AAErI,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAC7D,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAA;IAC5C,QAAQ,EAAE,kBAAkB,CAAA;CAC7B;AAsFD,UAAU,aAAc,SAAQ,kBAAkB;IAChD;;OAEG;IACH,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAE1B;;;;OAIG;IACH,QAAQ,CAAC,EAAE,kBAAkB,CAAA;IAE7B;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,CAAA;CACxB;AA+ID,wBAAgB,SAAS,CAAE,IAAI,GAAE,aAAkB,GAAG,kBAAkB,CAEvE"}