@libp2p/webtransport 4.0.28 → 4.0.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +3 -3
- package/dist/src/index.d.ts +12 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +55 -94
- package/dist/src/index.js.map +1 -1
- package/dist/src/listener.browser.d.ts +3 -0
- package/dist/src/listener.browser.d.ts.map +1 -0
- package/dist/src/listener.browser.js +4 -0
- package/dist/src/listener.browser.js.map +1 -0
- package/dist/src/listener.d.ts +15 -0
- package/dist/src/listener.d.ts.map +1 -0
- package/dist/src/listener.js +4 -0
- package/dist/src/listener.js.map +1 -0
- package/dist/src/muxer.d.ts +7 -0
- package/dist/src/muxer.d.ts.map +1 -0
- package/dist/src/muxer.js +70 -0
- package/dist/src/muxer.js.map +1 -0
- package/dist/src/stream.d.ts.map +1 -1
- package/dist/src/stream.js +79 -151
- package/dist/src/stream.js.map +1 -1
- package/dist/src/utils/generate-certificates.browser.d.ts +2 -0
- package/dist/src/utils/generate-certificates.browser.d.ts.map +1 -0
- package/dist/src/utils/generate-certificates.browser.js +4 -0
- package/dist/src/utils/generate-certificates.browser.js.map +1 -0
- package/dist/src/utils/generate-certificates.d.ts +8 -0
- package/dist/src/utils/generate-certificates.d.ts.map +1 -0
- package/dist/src/utils/generate-certificates.js +4 -0
- package/dist/src/utils/generate-certificates.js.map +1 -0
- package/dist/src/webtransport.browser.d.ts +2 -0
- package/dist/src/webtransport.browser.d.ts.map +1 -0
- package/dist/src/webtransport.browser.js +2 -0
- package/dist/src/webtransport.browser.js.map +1 -0
- package/dist/src/webtransport.d.ts +9 -0
- package/dist/src/webtransport.d.ts.map +1 -0
- package/dist/src/webtransport.js +15 -0
- package/dist/src/webtransport.js.map +1 -0
- package/dist/typedoc-urls.json +2 -0
- package/package.json +18 -9
- package/src/index.ts +74 -122
- package/src/listener.browser.ts +5 -0
- package/src/listener.ts +19 -0
- package/src/muxer.ts +95 -0
- package/src/stream.ts +90 -164
- package/src/utils/generate-certificates.browser.ts +3 -0
- package/src/utils/generate-certificates.ts +11 -0
- package/src/webtransport.browser.ts +1 -0
- package/src/webtransport.ts +17 -0
package/dist/src/stream.js
CHANGED
|
@@ -1,161 +1,89 @@
|
|
|
1
|
+
import { AbstractStream } from '@libp2p/utils/abstract-stream';
|
|
2
|
+
import { raceSignal } from 'race-signal';
|
|
1
3
|
import { Uint8ArrayList } from 'uint8arraylist';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
activeStreams.splice(index, 1);
|
|
11
|
-
stream.timeline.close = Date.now();
|
|
12
|
-
onStreamEnd?.(stream);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
let writerClosed = false;
|
|
16
|
-
let readerClosed = false;
|
|
17
|
-
(async function () {
|
|
18
|
-
const err = await writer.closed.catch((err) => err);
|
|
19
|
-
if (err != null) {
|
|
20
|
-
const msg = err.message;
|
|
21
|
-
if (!(msg.includes('aborted by the remote server') || msg.includes('STOP_SENDING'))) {
|
|
22
|
-
log.error(`WebTransport writer closed unexpectedly: streamId=${streamId} err=${err.message}`);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
writerClosed = true;
|
|
26
|
-
if (writerClosed && readerClosed) {
|
|
27
|
-
cleanupStreamFromActiveStreams();
|
|
28
|
-
}
|
|
29
|
-
})().catch(() => {
|
|
30
|
-
log.error('WebTransport failed to cleanup closed stream');
|
|
31
|
-
});
|
|
32
|
-
(async function () {
|
|
33
|
-
const err = await reader.closed.catch((err) => err);
|
|
34
|
-
if (err != null) {
|
|
35
|
-
log.error(`WebTransport reader closed unexpectedly: streamId=${streamId} err=${err.message}`);
|
|
36
|
-
}
|
|
37
|
-
readerClosed = true;
|
|
38
|
-
if (writerClosed && readerClosed) {
|
|
39
|
-
cleanupStreamFromActiveStreams();
|
|
40
|
-
}
|
|
41
|
-
})().catch(() => {
|
|
42
|
-
log.error('WebTransport failed to cleanup closed stream');
|
|
43
|
-
});
|
|
44
|
-
let sinkSunk = false;
|
|
45
|
-
const stream = {
|
|
46
|
-
id: streamId,
|
|
47
|
-
status: 'open',
|
|
48
|
-
writeStatus: 'ready',
|
|
49
|
-
readStatus: 'ready',
|
|
50
|
-
abort(err) {
|
|
51
|
-
if (!writerClosed) {
|
|
52
|
-
writer.abort(err)
|
|
53
|
-
.catch(err => {
|
|
54
|
-
log.error('could not abort stream', err);
|
|
55
|
-
});
|
|
56
|
-
writerClosed = true;
|
|
57
|
-
}
|
|
58
|
-
readerClosed = true;
|
|
59
|
-
this.status = 'aborted';
|
|
60
|
-
this.writeStatus = 'closed';
|
|
61
|
-
this.readStatus = 'closed';
|
|
62
|
-
this.timeline.reset =
|
|
63
|
-
this.timeline.close =
|
|
64
|
-
this.timeline.closeRead =
|
|
65
|
-
this.timeline.closeWrite = Date.now();
|
|
66
|
-
cleanupStreamFromActiveStreams();
|
|
67
|
-
},
|
|
68
|
-
async close(options) {
|
|
69
|
-
this.status = 'closing';
|
|
70
|
-
await Promise.all([
|
|
71
|
-
stream.closeRead(options),
|
|
72
|
-
stream.closeWrite(options)
|
|
73
|
-
]);
|
|
74
|
-
cleanupStreamFromActiveStreams();
|
|
75
|
-
this.status = 'closed';
|
|
76
|
-
this.timeline.close = Date.now();
|
|
77
|
-
},
|
|
78
|
-
async closeRead(options) {
|
|
79
|
-
if (!readerClosed) {
|
|
80
|
-
this.readStatus = 'closing';
|
|
81
|
-
try {
|
|
82
|
-
await reader.cancel();
|
|
83
|
-
}
|
|
84
|
-
catch (err) {
|
|
85
|
-
if (err.toString().includes('RESET_STREAM') === true) {
|
|
86
|
-
writerClosed = true;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
this.timeline.closeRead = Date.now();
|
|
90
|
-
this.readStatus = 'closed';
|
|
91
|
-
readerClosed = true;
|
|
92
|
-
}
|
|
93
|
-
if (writerClosed) {
|
|
94
|
-
cleanupStreamFromActiveStreams();
|
|
95
|
-
}
|
|
96
|
-
},
|
|
97
|
-
async closeWrite(options) {
|
|
98
|
-
if (!writerClosed) {
|
|
99
|
-
writerClosed = true;
|
|
100
|
-
this.writeStatus = 'closing';
|
|
101
|
-
try {
|
|
102
|
-
await writer.close();
|
|
103
|
-
}
|
|
104
|
-
catch (err) {
|
|
105
|
-
if (err.toString().includes('RESET_STREAM') === true) {
|
|
106
|
-
readerClosed = true;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
this.timeline.closeWrite = Date.now();
|
|
110
|
-
this.writeStatus = 'closed';
|
|
111
|
-
}
|
|
112
|
-
if (readerClosed) {
|
|
113
|
-
cleanupStreamFromActiveStreams();
|
|
114
|
-
}
|
|
115
|
-
},
|
|
116
|
-
direction,
|
|
117
|
-
timeline: { open: Date.now() },
|
|
118
|
-
metadata: {},
|
|
119
|
-
source: (async function* () {
|
|
4
|
+
class WebTransportStream extends AbstractStream {
|
|
5
|
+
writer;
|
|
6
|
+
reader;
|
|
7
|
+
constructor(init) {
|
|
8
|
+
super(init);
|
|
9
|
+
this.writer = init.bidiStream.writable.getWriter();
|
|
10
|
+
this.reader = init.bidiStream.readable.getReader();
|
|
11
|
+
Promise.resolve().then(async () => {
|
|
120
12
|
while (true) {
|
|
121
|
-
const
|
|
122
|
-
if (
|
|
123
|
-
|
|
124
|
-
if (writerClosed) {
|
|
125
|
-
cleanupStreamFromActiveStreams();
|
|
126
|
-
}
|
|
13
|
+
const result = await this.reader.read();
|
|
14
|
+
if (result.done) {
|
|
15
|
+
init.log('remote closed write');
|
|
127
16
|
return;
|
|
128
17
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
})(),
|
|
132
|
-
sink: async function (source) {
|
|
133
|
-
if (sinkSunk) {
|
|
134
|
-
throw new Error('sink already called on stream');
|
|
135
|
-
}
|
|
136
|
-
sinkSunk = true;
|
|
137
|
-
try {
|
|
138
|
-
this.writeStatus = 'writing';
|
|
139
|
-
for await (const chunks of source) {
|
|
140
|
-
if (chunks instanceof Uint8Array) {
|
|
141
|
-
await writer.write(chunks);
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
for (const buf of chunks) {
|
|
145
|
-
await writer.write(buf);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
18
|
+
if (result.value != null) {
|
|
19
|
+
this.sourcePush(new Uint8ArrayList(result.value));
|
|
148
20
|
}
|
|
149
|
-
this.writeStatus = 'done';
|
|
150
21
|
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
22
|
+
})
|
|
23
|
+
.catch(err => {
|
|
24
|
+
init.log.error('error reading from stream', err);
|
|
25
|
+
this.abort(err);
|
|
26
|
+
})
|
|
27
|
+
.finally(() => {
|
|
28
|
+
this.remoteCloseWrite();
|
|
29
|
+
});
|
|
30
|
+
void this.writer.closed
|
|
31
|
+
.then(() => {
|
|
32
|
+
init.log('writer closed');
|
|
33
|
+
})
|
|
34
|
+
.catch((err) => {
|
|
35
|
+
init.log('writer close promise rejected', err);
|
|
36
|
+
})
|
|
37
|
+
.finally(() => {
|
|
38
|
+
this.remoteCloseRead();
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
sendNewStream(options) {
|
|
42
|
+
// this is a no-op
|
|
43
|
+
}
|
|
44
|
+
async sendData(buf, options) {
|
|
45
|
+
for await (const chunk of buf) {
|
|
46
|
+
this.log('sendData waiting for writer to be ready');
|
|
47
|
+
await raceSignal(this.writer.ready, options?.signal);
|
|
48
|
+
// the streams spec recommends not waiting for data to be sent
|
|
49
|
+
// https://streams.spec.whatwg.org/#example-manual-write-dont-await
|
|
50
|
+
this.writer.write(chunk)
|
|
51
|
+
.catch(err => {
|
|
52
|
+
this.log.error('error sending stream data', err);
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async sendReset(options) {
|
|
57
|
+
this.log('sendReset aborting writer');
|
|
58
|
+
await raceSignal(this.writer.abort(), options?.signal);
|
|
59
|
+
this.log('sendReset aborted writer');
|
|
60
|
+
}
|
|
61
|
+
async sendCloseWrite(options) {
|
|
62
|
+
this.log('sendCloseWrite closing writer');
|
|
63
|
+
await raceSignal(this.writer.close(), options?.signal);
|
|
64
|
+
this.log('sendCloseWrite closed writer');
|
|
65
|
+
}
|
|
66
|
+
async sendCloseRead(options) {
|
|
67
|
+
this.log('sendCloseRead cancelling reader');
|
|
68
|
+
await raceSignal(this.reader.cancel(), options?.signal);
|
|
69
|
+
this.log('sendCloseRead cancelled reader');
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
export async function webtransportBiDiStreamToStream(bidiStream, streamId, direction, activeStreams, onStreamEnd, logger) {
|
|
73
|
+
const log = logger.forComponent(`libp2p:webtransport:stream:${direction}:${streamId}`);
|
|
74
|
+
const stream = new WebTransportStream({
|
|
75
|
+
bidiStream,
|
|
76
|
+
id: streamId,
|
|
77
|
+
direction,
|
|
78
|
+
log,
|
|
79
|
+
onEnd: () => {
|
|
80
|
+
const index = activeStreams.findIndex(s => s === stream);
|
|
81
|
+
if (index !== -1) {
|
|
82
|
+
activeStreams.splice(index, 1);
|
|
155
83
|
}
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
};
|
|
84
|
+
onStreamEnd?.(stream);
|
|
85
|
+
}
|
|
86
|
+
});
|
|
159
87
|
return stream;
|
|
160
88
|
}
|
|
161
89
|
//# sourceMappingURL=stream.js.map
|
package/dist/src/stream.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stream.js","sourceRoot":"","sources":["../../src/stream.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,
|
|
1
|
+
{"version":3,"file":"stream.js","sourceRoot":"","sources":["../../src/stream.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-certificates.browser.d.ts","sourceRoot":"","sources":["../../../src/utils/generate-certificates.browser.ts"],"names":[],"mappings":"AAAA,wBAAsB,gCAAgC,IAAK,OAAO,CAAC,GAAG,CAAC,CAEtE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-certificates.browser.js","sourceRoot":"","sources":["../../../src/utils/generate-certificates.browser.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,KAAK,UAAU,gCAAgC;IACpD,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;AACpC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { WebTransportCertificate } from '../../src/index.js';
|
|
2
|
+
export interface GenerateWebTransportCertificateOptions {
|
|
3
|
+
days: number;
|
|
4
|
+
start?: Date;
|
|
5
|
+
extensions?: any[];
|
|
6
|
+
}
|
|
7
|
+
export declare function generateWebTransportCertificates(options?: GenerateWebTransportCertificateOptions[]): Promise<WebTransportCertificate[]>;
|
|
8
|
+
//# sourceMappingURL=generate-certificates.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-certificates.d.ts","sourceRoot":"","sources":["../../../src/utils/generate-certificates.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAA;AAEjE,MAAM,WAAW,sCAAsC;IACrD,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,CAAC,EAAE,IAAI,CAAA;IACZ,UAAU,CAAC,EAAE,GAAG,EAAE,CAAA;CACnB;AAED,wBAAsB,gCAAgC,CAAE,OAAO,GAAE,sCAAsC,EAAO,GAAG,OAAO,CAAC,uBAAuB,EAAE,CAAC,CAElJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-certificates.js","sourceRoot":"","sources":["../../../src/utils/generate-certificates.ts"],"names":[],"mappings":"AAQA,MAAM,CAAC,KAAK,UAAU,gCAAgC,CAAE,UAAoD,EAAE;IAC5G,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;AACpC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webtransport.browser.d.ts","sourceRoot":"","sources":["../../src/webtransport.browser.ts"],"names":[],"mappings":"AAAA,eAAe,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webtransport.browser.js","sourceRoot":"","sources":["../../src/webtransport.browser.ts"],"names":[],"mappings":"AAAA,eAAe,YAAY,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export default class WebTransport {
|
|
2
|
+
constructor(url: string | URL, options?: WebTransportOptions);
|
|
3
|
+
close(): void;
|
|
4
|
+
createBidirectionalStream(): Promise<WebTransportBidirectionalStream>;
|
|
5
|
+
closed: Promise<never>;
|
|
6
|
+
ready: Promise<never>;
|
|
7
|
+
incomingBidirectionalStreams: ReadableStream;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=webtransport.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webtransport.d.ts","sourceRoot":"","sources":["../../src/webtransport.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAO,YAAY;gBAClB,GAAG,EAAE,MAAM,GAAG,GAAG,EAAE,OAAO,CAAC,EAAE,mBAAmB;IAI7D,KAAK,IAAK,IAAI;IAIR,yBAAyB,IAAK,OAAO,CAAC,+BAA+B,CAAC;IAIrE,MAAM,iBAA0D;IAChE,KAAK,iBAA0D;IAC/D,4BAA4B,EAAE,cAAc,CAAA;CACpD"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export default class WebTransport {
|
|
2
|
+
constructor(url, options) {
|
|
3
|
+
throw new Error('Only supported in browsers');
|
|
4
|
+
}
|
|
5
|
+
close() {
|
|
6
|
+
throw new Error('Only supported in browsers');
|
|
7
|
+
}
|
|
8
|
+
async createBidirectionalStream() {
|
|
9
|
+
throw new Error('Only supported in browsers');
|
|
10
|
+
}
|
|
11
|
+
closed = Promise.reject(new Error('Only supported in browsers'));
|
|
12
|
+
ready = Promise.reject(new Error('Only supported in browsers'));
|
|
13
|
+
incomingBidirectionalStreams;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=webtransport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webtransport.js","sourceRoot":"","sources":["../../src/webtransport.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAO,YAAY;IAC/B,YAAa,GAAiB,EAAE,OAA6B;QAC3D,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/C,CAAC;IAED,KAAK;QACH,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/C,CAAC;IAED,KAAK,CAAC,yBAAyB;QAC7B,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/C,CAAC;IAEM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC,CAAA;IAChE,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC,CAAA;IAC/D,4BAA4B,CAAgB;CACpD"}
|
package/dist/typedoc-urls.json
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
{
|
|
2
|
+
"WebTransportCertificate": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_webtransport.WebTransportCertificate.html",
|
|
3
|
+
".:WebTransportCertificate": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_webtransport.WebTransportCertificate.html",
|
|
2
4
|
"WebTransportComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_webtransport.WebTransportComponents.html",
|
|
3
5
|
".:WebTransportComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_webtransport.WebTransportComponents.html",
|
|
4
6
|
"WebTransportInit": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_webtransport.WebTransportInit.html",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/webtransport",
|
|
3
|
-
"version": "4.0.
|
|
3
|
+
"version": "4.0.29",
|
|
4
4
|
"description": "JavaScript implementation of the WebTransport module that libp2p uses and that implements the interface-transport spec",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-webtransport#readme",
|
|
@@ -51,27 +51,36 @@
|
|
|
51
51
|
},
|
|
52
52
|
"dependencies": {
|
|
53
53
|
"@chainsafe/libp2p-noise": "^15.0.0",
|
|
54
|
-
"@libp2p/interface": "^1.3.
|
|
55
|
-
"@libp2p/peer-id": "^4.1.
|
|
54
|
+
"@libp2p/interface": "^1.3.1",
|
|
55
|
+
"@libp2p/peer-id": "^4.1.1",
|
|
56
|
+
"@libp2p/utils": "^5.4.0",
|
|
56
57
|
"@multiformats/multiaddr": "^12.2.1",
|
|
57
58
|
"@multiformats/multiaddr-matcher": "^1.2.0",
|
|
58
59
|
"it-stream-types": "^2.0.1",
|
|
59
60
|
"multiformats": "^13.1.0",
|
|
61
|
+
"race-signal": "^1.0.2",
|
|
60
62
|
"uint8arraylist": "^2.4.8",
|
|
61
63
|
"uint8arrays": "^5.0.3"
|
|
62
64
|
},
|
|
63
65
|
"devDependencies": {
|
|
64
|
-
"@libp2p/logger": "^4.0.
|
|
65
|
-
"@libp2p/peer-id-factory": "^4.1.
|
|
66
|
+
"@libp2p/logger": "^4.0.12",
|
|
67
|
+
"@libp2p/peer-id-factory": "^4.1.1",
|
|
68
|
+
"@noble/hashes": "^1.4.0",
|
|
66
69
|
"aegir": "^42.2.5",
|
|
67
|
-
"
|
|
68
|
-
"
|
|
70
|
+
"it-map": "^3.1.0",
|
|
71
|
+
"it-to-buffer": "^4.0.7",
|
|
72
|
+
"libp2p": "^1.5.0",
|
|
73
|
+
"p-defer": "^4.0.1",
|
|
74
|
+
"p-wait-for": "^5.0.2"
|
|
69
75
|
},
|
|
70
76
|
"browser": {
|
|
71
|
-
"./dist/src/listener.js": "./dist/src/listener.browser.js"
|
|
77
|
+
"./dist/src/listener.js": "./dist/src/listener.browser.js",
|
|
78
|
+
"./dist/src/webtransport.js": "./dist/src/webtransport.browser.js"
|
|
72
79
|
},
|
|
73
80
|
"react-native": {
|
|
74
|
-
"./dist/src/listener.js": "./dist/src/listener.browser.js"
|
|
81
|
+
"./dist/src/listener.js": "./dist/src/listener.browser.js",
|
|
82
|
+
"./dist/src/webtransport.js": "./dist/src/webtransport.browser.js",
|
|
83
|
+
"./dist/src/utils/generate-certificates.js": "./dist/src/utils/generate-certificates.browser.js"
|
|
75
84
|
},
|
|
76
85
|
"sideEffects": false
|
|
77
86
|
}
|