msw 2.3.0-ws.rc-2 → 2.3.0-ws.rc-4
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/lib/browser/index.js +8 -8
- package/lib/browser/index.js.map +1 -1
- package/lib/browser/index.mjs +8 -8
- package/lib/browser/index.mjs.map +1 -1
- package/lib/core/{GraphQLHandler-4DPdxG0R.d.mts → GraphQLHandler-CzcXr7At.d.mts} +1 -1
- package/lib/core/{GraphQLHandler-3gvpA65n.d.ts → GraphQLHandler-DGyzNtRQ.d.ts} +1 -1
- package/lib/core/HttpResponse.d.mts +1 -1
- package/lib/core/HttpResponse.d.ts +1 -1
- package/lib/core/SetupApi.d.mts +1 -1
- package/lib/core/SetupApi.d.ts +1 -1
- package/lib/core/getResponse.d.mts +1 -1
- package/lib/core/getResponse.d.ts +1 -1
- package/lib/core/graphql.d.mts +2 -2
- package/lib/core/graphql.d.ts +2 -2
- package/lib/core/handlers/GraphQLHandler.d.mts +2 -2
- package/lib/core/handlers/GraphQLHandler.d.ts +2 -2
- package/lib/core/handlers/HttpHandler.d.mts +1 -1
- package/lib/core/handlers/HttpHandler.d.ts +1 -1
- package/lib/core/handlers/RequestHandler.d.mts +1 -1
- package/lib/core/handlers/RequestHandler.d.ts +1 -1
- package/lib/core/http.d.mts +1 -1
- package/lib/core/http.d.ts +1 -1
- package/lib/core/index.d.mts +3 -3
- package/lib/core/index.d.ts +3 -3
- package/lib/core/index.js +1 -1
- package/lib/core/index.js.map +1 -1
- package/lib/core/index.mjs +1 -1
- package/lib/core/index.mjs.map +1 -1
- package/lib/core/passthrough.d.mts +1 -1
- package/lib/core/passthrough.d.ts +1 -1
- package/lib/core/utils/HttpResponse/decorators.d.mts +1 -1
- package/lib/core/utils/HttpResponse/decorators.d.ts +1 -1
- package/lib/core/utils/executeHandlers.d.mts +1 -1
- package/lib/core/utils/executeHandlers.d.ts +1 -1
- package/lib/core/utils/handleRequest.d.mts +1 -1
- package/lib/core/utils/handleRequest.d.ts +1 -1
- package/lib/core/utils/internal/parseGraphQLRequest.d.mts +2 -2
- package/lib/core/utils/internal/parseGraphQLRequest.d.ts +2 -2
- package/lib/core/utils/internal/parseMultipartData.d.mts +1 -1
- package/lib/core/utils/internal/parseMultipartData.d.ts +1 -1
- package/lib/core/utils/internal/requestHandlerUtils.d.mts +1 -1
- package/lib/core/utils/internal/requestHandlerUtils.d.ts +1 -1
- package/lib/core/{utils → ws}/handleWebSocketEvent.d.mts +2 -2
- package/lib/core/{utils → ws}/handleWebSocketEvent.d.ts +2 -2
- package/lib/core/{utils → ws}/handleWebSocketEvent.js +1 -4
- package/lib/core/ws/handleWebSocketEvent.js.map +1 -0
- package/lib/core/{utils → ws}/handleWebSocketEvent.mjs +1 -4
- package/lib/core/ws/handleWebSocketEvent.mjs.map +1 -0
- package/lib/core/ws/utils/attachWebSocketLogger.js +15 -9
- package/lib/core/ws/utils/attachWebSocketLogger.js.map +1 -1
- package/lib/core/ws/utils/attachWebSocketLogger.mjs +15 -9
- package/lib/core/ws/utils/attachWebSocketLogger.mjs.map +1 -1
- package/lib/core/{ws/ws.d.mts → ws.d.mts} +19 -14
- package/lib/core/{ws/ws.d.ts → ws.d.ts} +19 -14
- package/lib/core/{ws/ws.js → ws.js} +4 -23
- package/lib/core/ws.js.map +1 -0
- package/lib/core/{ws/ws.mjs → ws.mjs} +4 -23
- package/lib/core/ws.mjs.map +1 -0
- package/lib/iife/index.js +136 -107
- package/lib/iife/index.js.map +1 -1
- package/lib/mockServiceWorker.js +1 -1
- package/lib/native/index.js +1 -1
- package/lib/native/index.js.map +1 -1
- package/lib/native/index.mjs +1 -1
- package/lib/native/index.mjs.map +1 -1
- package/lib/node/index.js +1 -1
- package/lib/node/index.js.map +1 -1
- package/lib/node/index.mjs +1 -1
- package/lib/node/index.mjs.map +1 -1
- package/package.json +3 -3
- package/src/browser/setupWorker/setupWorker.ts +1 -1
- package/src/core/index.ts +1 -1
- package/src/core/{utils → ws}/handleWebSocketEvent.ts +1 -4
- package/src/core/ws/utils/attachWebSocketLogger.ts +16 -9
- package/src/core/{ws/ws.test.ts → ws.test.ts} +1 -1
- package/src/core/{ws/ws.ts → ws.ts} +49 -35
- package/src/node/SetupServerCommonApi.ts +1 -1
- package/lib/core/utils/handleWebSocketEvent.js.map +0 -1
- package/lib/core/utils/handleWebSocketEvent.mjs.map +0 -1
- package/lib/core/ws/ws.js.map +0 -1
- package/lib/core/ws/ws.mjs.map +0 -1
- /package/lib/core/{HttpResponse-aJY-D0oG.d.ts → HttpResponse-BOzDwzB6.d.ts} +0 -0
- /package/lib/core/{HttpResponse-xuSipbNt.d.mts → HttpResponse-CSyJ1cbO.d.mts} +0 -0
package/lib/iife/index.js
CHANGED
|
@@ -1070,7 +1070,7 @@ var MockServiceWorker = (() => {
|
|
|
1070
1070
|
if (options === void 0) {
|
|
1071
1071
|
options = {};
|
|
1072
1072
|
}
|
|
1073
|
-
var _a2 = options.strict, strict = _a2 === void 0 ? false : _a2, _b2 = options.start, start = _b2 === void 0 ? true : _b2,
|
|
1073
|
+
var _a2 = options.strict, strict = _a2 === void 0 ? false : _a2, _b2 = options.start, start = _b2 === void 0 ? true : _b2, _c2 = options.end, end = _c2 === void 0 ? true : _c2, _d = options.encode, encode = _d === void 0 ? function(x) {
|
|
1074
1074
|
return x;
|
|
1075
1075
|
} : _d, _e = options.delimiter, delimiter = _e === void 0 ? "/#?" : _e, _f = options.endsWith, endsWith = _f === void 0 ? "" : _f;
|
|
1076
1076
|
var endsWithRe = "[".concat(escapeString(endsWith), "]|$");
|
|
@@ -1129,7 +1129,7 @@ var MockServiceWorker = (() => {
|
|
|
1129
1129
|
return stringToRegexp(path, keys, options);
|
|
1130
1130
|
}
|
|
1131
1131
|
|
|
1132
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
1132
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-UJZOJSMP.mjs
|
|
1133
1133
|
var encoder = new TextEncoder();
|
|
1134
1134
|
function encodeBuffer(text) {
|
|
1135
1135
|
return encoder.encode(text);
|
|
@@ -1155,7 +1155,7 @@ var MockServiceWorker = (() => {
|
|
|
1155
1155
|
return RESPONSE_STATUS_CODES_WITHOUT_BODY.has(status);
|
|
1156
1156
|
}
|
|
1157
1157
|
|
|
1158
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
1158
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-HAGW22AN.mjs
|
|
1159
1159
|
var IS_PATCHED_MODULE = Symbol("isPatchedModule");
|
|
1160
1160
|
|
|
1161
1161
|
// node_modules/.pnpm/is-node-process@1.2.0/node_modules/is-node-process/lib/index.mjs
|
|
@@ -1445,7 +1445,7 @@ var MockServiceWorker = (() => {
|
|
|
1445
1445
|
return message3.toString();
|
|
1446
1446
|
}
|
|
1447
1447
|
|
|
1448
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
1448
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-QED3Q6Z2.mjs
|
|
1449
1449
|
var INTERNAL_REQUEST_ID_HEADER_NAME = "x-interceptors-internal-request-id";
|
|
1450
1450
|
function getGlobalSymbol(symbol) {
|
|
1451
1451
|
return (
|
|
@@ -1593,7 +1593,7 @@ var MockServiceWorker = (() => {
|
|
|
1593
1593
|
return Math.random().toString(16).slice(2);
|
|
1594
1594
|
}
|
|
1595
1595
|
|
|
1596
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
1596
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/index.mjs
|
|
1597
1597
|
var BatchInterceptor = class extends Interceptor {
|
|
1598
1598
|
constructor(options) {
|
|
1599
1599
|
BatchInterceptor.symbol = Symbol(options.name);
|
|
@@ -4833,7 +4833,7 @@ spurious results.`);
|
|
|
4833
4833
|
}
|
|
4834
4834
|
}
|
|
4835
4835
|
|
|
4836
|
-
// node_modules/.pnpm/headers-polyfill@4.0.
|
|
4836
|
+
// node_modules/.pnpm/headers-polyfill@4.0.3/node_modules/headers-polyfill/lib/index.mjs
|
|
4837
4837
|
var __create4 = Object.create;
|
|
4838
4838
|
var __defProp6 = Object.defineProperty;
|
|
4839
4839
|
var __getOwnPropDesc5 = Object.getOwnPropertyDescriptor;
|
|
@@ -5109,10 +5109,12 @@ spurious results.`);
|
|
|
5109
5109
|
var HEADER_VALUE_DELIMITER = ", ";
|
|
5110
5110
|
var _a;
|
|
5111
5111
|
var _b;
|
|
5112
|
+
var _c;
|
|
5112
5113
|
var Headers2 = class _Headers {
|
|
5113
5114
|
constructor(init) {
|
|
5114
5115
|
this[_a] = {};
|
|
5115
5116
|
this[_b] = /* @__PURE__ */ new Map();
|
|
5117
|
+
this[_c] = "Headers";
|
|
5116
5118
|
if (["Headers", "HeadersPolyfill"].includes(init?.constructor.name) || init instanceof _Headers || typeof globalThis.Headers !== "undefined" && init instanceof globalThis.Headers) {
|
|
5117
5119
|
const initialHeaders = init;
|
|
5118
5120
|
initialHeaders.forEach((value, name) => {
|
|
@@ -5135,7 +5137,7 @@ spurious results.`);
|
|
|
5135
5137
|
});
|
|
5136
5138
|
}
|
|
5137
5139
|
}
|
|
5138
|
-
[(_a = NORMALIZED_HEADERS, _b = RAW_HEADER_NAMES, Symbol.iterator)]() {
|
|
5140
|
+
[(_a = NORMALIZED_HEADERS, _b = RAW_HEADER_NAMES, _c = Symbol.toStringTag, Symbol.iterator)]() {
|
|
5139
5141
|
return this.entries();
|
|
5140
5142
|
}
|
|
5141
5143
|
*keys() {
|
|
@@ -5757,13 +5759,13 @@ Consider naming this operation or using "graphql.operation()" request handler to
|
|
|
5757
5759
|
}
|
|
5758
5760
|
};
|
|
5759
5761
|
|
|
5760
|
-
// src/core/ws
|
|
5762
|
+
// src/core/ws.ts
|
|
5761
5763
|
var wsBroadcastChannel = new BroadcastChannel("msw:ws-client-manager");
|
|
5762
5764
|
function createWebSocketLinkHandler(url) {
|
|
5763
5765
|
invariant(url, "Expected a WebSocket server URL but got undefined");
|
|
5764
5766
|
invariant(
|
|
5765
5767
|
isPath(url),
|
|
5766
|
-
"Expected a WebSocket server URL but got %s",
|
|
5768
|
+
"Expected a WebSocket server URL to be a valid path but got %s",
|
|
5767
5769
|
typeof url
|
|
5768
5770
|
);
|
|
5769
5771
|
const clientManager = new WebSocketClientManager(wsBroadcastChannel);
|
|
@@ -5777,28 +5779,9 @@ Consider naming this operation or using "graphql.operation()" request handler to
|
|
|
5777
5779
|
handler[kEmitter].on(event, listener);
|
|
5778
5780
|
return handler;
|
|
5779
5781
|
},
|
|
5780
|
-
/**
|
|
5781
|
-
* Broadcasts the given data to all WebSocket clients.
|
|
5782
|
-
*
|
|
5783
|
-
* @example
|
|
5784
|
-
* const service = ws.link('wss://example.com')
|
|
5785
|
-
* service.on('connection', () => {
|
|
5786
|
-
* service.broadcast('hello, everyone!')
|
|
5787
|
-
* })
|
|
5788
|
-
*/
|
|
5789
5782
|
broadcast(data) {
|
|
5790
5783
|
this.broadcastExcept([], data);
|
|
5791
5784
|
},
|
|
5792
|
-
/**
|
|
5793
|
-
* Broadcasts the given data to all WebSocket clients
|
|
5794
|
-
* except the ones provided in the `clients` argument.
|
|
5795
|
-
*
|
|
5796
|
-
* @example
|
|
5797
|
-
* const service = ws.link('wss://example.com')
|
|
5798
|
-
* service.on('connection', ({ client }) => {
|
|
5799
|
-
* service.broadcastExcept(client, 'hi, the rest of you!')
|
|
5800
|
-
* })
|
|
5801
|
-
*/
|
|
5802
5785
|
broadcastExcept(clients, data) {
|
|
5803
5786
|
const ignoreClients = Array.prototype.concat(clients).map((client) => client.id);
|
|
5804
5787
|
clientManager.clients.forEach((otherClient) => {
|
|
@@ -6691,7 +6674,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
6691
6674
|
}
|
|
6692
6675
|
};
|
|
6693
6676
|
|
|
6694
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
6677
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-OUWBQF3Z.mjs
|
|
6695
6678
|
var RequestController = class {
|
|
6696
6679
|
constructor(request) {
|
|
6697
6680
|
this.request = request;
|
|
@@ -6729,7 +6712,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
6729
6712
|
}
|
|
6730
6713
|
}
|
|
6731
6714
|
|
|
6732
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
6715
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-3FNUI33J.mjs
|
|
6733
6716
|
function isPropertyAccessible2(obj, key) {
|
|
6734
6717
|
try {
|
|
6735
6718
|
obj[key];
|
|
@@ -6876,7 +6859,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
6876
6859
|
});
|
|
6877
6860
|
}
|
|
6878
6861
|
|
|
6879
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
6862
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/chunk-VYFS2IF2.mjs
|
|
6880
6863
|
function concatArrayBuffer(left, right) {
|
|
6881
6864
|
const result = new Uint8Array(left.byteLength + right.byteLength);
|
|
6882
6865
|
result.set(left, 0);
|
|
@@ -7701,7 +7684,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
7701
7684
|
}
|
|
7702
7685
|
}
|
|
7703
7686
|
|
|
7704
|
-
// node_modules/.pnpm/@mswjs+interceptors@0.
|
|
7687
|
+
// node_modules/.pnpm/@mswjs+interceptors@0.27.0/node_modules/@mswjs/interceptors/lib/browser/interceptors/WebSocket/index.mjs
|
|
7705
7688
|
function bindEvent(target, event) {
|
|
7706
7689
|
Object.defineProperties(event, {
|
|
7707
7690
|
target: {
|
|
@@ -7753,16 +7736,25 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
7753
7736
|
this.id = createRequestId();
|
|
7754
7737
|
this.url = new URL(socket.url);
|
|
7755
7738
|
this[kEmitter2] = new EventTarget();
|
|
7756
|
-
this.transport.
|
|
7757
|
-
|
|
7758
|
-
|
|
7739
|
+
this.transport.addEventListener("outgoing", (event) => {
|
|
7740
|
+
const message3 = bindEvent(
|
|
7741
|
+
this.socket,
|
|
7742
|
+
new CancelableMessageEvent("message", {
|
|
7743
|
+
data: event.data,
|
|
7744
|
+
origin: event.origin,
|
|
7745
|
+
cancelable: true
|
|
7746
|
+
})
|
|
7759
7747
|
);
|
|
7760
|
-
|
|
7761
|
-
|
|
7748
|
+
this[kEmitter2].dispatchEvent(message3);
|
|
7749
|
+
if (message3.defaultPrevented) {
|
|
7750
|
+
event.preventDefault();
|
|
7751
|
+
}
|
|
7752
|
+
});
|
|
7753
|
+
this.transport.addEventListener("close", (event) => {
|
|
7762
7754
|
this[kEmitter2].dispatchEvent(
|
|
7763
7755
|
bindEvent(this.socket, new CloseEvent("close", event))
|
|
7764
7756
|
);
|
|
7765
|
-
};
|
|
7757
|
+
});
|
|
7766
7758
|
}
|
|
7767
7759
|
/**
|
|
7768
7760
|
* Listen for the outgoing events from the connected WebSocket client.
|
|
@@ -7949,35 +7941,20 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
7949
7941
|
this.createConnection = createConnection;
|
|
7950
7942
|
this[kEmitter22] = new EventTarget();
|
|
7951
7943
|
this.mockCloseController = new AbortController();
|
|
7952
|
-
this.transport.
|
|
7953
|
-
|
|
7954
|
-
|
|
7955
|
-
new CancelableMessageEvent("message", {
|
|
7956
|
-
data: event.data,
|
|
7957
|
-
origin: event.origin,
|
|
7958
|
-
cancelable: true
|
|
7959
|
-
})
|
|
7960
|
-
);
|
|
7961
|
-
this[kEmitter22].dispatchEvent(messageEvent);
|
|
7962
|
-
if (!messageEvent.defaultPrevented) {
|
|
7963
|
-
this.socket.dispatchEvent(
|
|
7964
|
-
bindEvent(
|
|
7965
|
-
/**
|
|
7966
|
-
* @note Bind the forwarded original server events
|
|
7967
|
-
* to the mock WebSocket instance so it would
|
|
7968
|
-
* dispatch them straight away.
|
|
7969
|
-
*/
|
|
7970
|
-
this.socket,
|
|
7971
|
-
// Clone the message event again to prevent
|
|
7972
|
-
// the "already being dispatched" exception.
|
|
7973
|
-
new MessageEvent("message", {
|
|
7974
|
-
data: event.data,
|
|
7975
|
-
origin: event.origin
|
|
7976
|
-
})
|
|
7977
|
-
)
|
|
7978
|
-
);
|
|
7944
|
+
this.transport.addEventListener("outgoing", (event) => {
|
|
7945
|
+
if (this.readyState === -1) {
|
|
7946
|
+
return;
|
|
7979
7947
|
}
|
|
7980
|
-
|
|
7948
|
+
queueMicrotask(() => {
|
|
7949
|
+
if (!event.defaultPrevented) {
|
|
7950
|
+
this.send(event.data);
|
|
7951
|
+
}
|
|
7952
|
+
});
|
|
7953
|
+
});
|
|
7954
|
+
this.transport.addEventListener(
|
|
7955
|
+
"incoming",
|
|
7956
|
+
this.handleIncomingMessage.bind(this)
|
|
7957
|
+
);
|
|
7981
7958
|
}
|
|
7982
7959
|
/**
|
|
7983
7960
|
* Server ready state.
|
|
@@ -8011,7 +7988,15 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8011
7988
|
{ once: true }
|
|
8012
7989
|
);
|
|
8013
7990
|
realWebSocket.addEventListener("message", (event) => {
|
|
8014
|
-
this.transport.
|
|
7991
|
+
this.transport.dispatchEvent(
|
|
7992
|
+
bindEvent(
|
|
7993
|
+
this.realWebSocket,
|
|
7994
|
+
new MessageEvent("incoming", {
|
|
7995
|
+
data: event.data,
|
|
7996
|
+
origin: event.origin
|
|
7997
|
+
})
|
|
7998
|
+
)
|
|
7999
|
+
);
|
|
8015
8000
|
});
|
|
8016
8001
|
this.socket.addEventListener("close", this.handleMockClose.bind(this), {
|
|
8017
8002
|
signal: this.mockCloseController.signal
|
|
@@ -8092,6 +8077,35 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8092
8077
|
);
|
|
8093
8078
|
});
|
|
8094
8079
|
}
|
|
8080
|
+
handleIncomingMessage(event) {
|
|
8081
|
+
const messageEvent = bindEvent(
|
|
8082
|
+
event.target,
|
|
8083
|
+
new CancelableMessageEvent("message", {
|
|
8084
|
+
data: event.data,
|
|
8085
|
+
origin: event.origin,
|
|
8086
|
+
cancelable: true
|
|
8087
|
+
})
|
|
8088
|
+
);
|
|
8089
|
+
this[kEmitter22].dispatchEvent(messageEvent);
|
|
8090
|
+
if (!messageEvent.defaultPrevented) {
|
|
8091
|
+
this.socket.dispatchEvent(
|
|
8092
|
+
bindEvent(
|
|
8093
|
+
/**
|
|
8094
|
+
* @note Bind the forwarded original server events
|
|
8095
|
+
* to the mock WebSocket instance so it would
|
|
8096
|
+
* dispatch them straight away.
|
|
8097
|
+
*/
|
|
8098
|
+
this.socket,
|
|
8099
|
+
// Clone the message event again to prevent
|
|
8100
|
+
// the "already being dispatched" exception.
|
|
8101
|
+
new MessageEvent("message", {
|
|
8102
|
+
data: event.data,
|
|
8103
|
+
origin: event.origin
|
|
8104
|
+
})
|
|
8105
|
+
)
|
|
8106
|
+
);
|
|
8107
|
+
}
|
|
8108
|
+
}
|
|
8095
8109
|
handleMockClose(_event) {
|
|
8096
8110
|
if (this.realWebSocket) {
|
|
8097
8111
|
this.realWebSocket.close();
|
|
@@ -8109,41 +8123,53 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8109
8123
|
}
|
|
8110
8124
|
}
|
|
8111
8125
|
};
|
|
8112
|
-
var
|
|
8113
|
-
};
|
|
8114
|
-
var WebSocketClassTransport = class extends WebSocketTransport {
|
|
8126
|
+
var WebSocketClassTransport = class extends EventTarget {
|
|
8115
8127
|
constructor(socket) {
|
|
8116
8128
|
super();
|
|
8117
8129
|
this.socket = socket;
|
|
8118
|
-
this.
|
|
8119
|
-
|
|
8120
|
-
this.onIncoming = () => {
|
|
8121
|
-
};
|
|
8122
|
-
this.onClose = () => {
|
|
8123
|
-
};
|
|
8124
|
-
this.socket.addEventListener("close", (event) => this.onClose(event), {
|
|
8125
|
-
once: true
|
|
8130
|
+
this.socket.addEventListener("close", (event) => {
|
|
8131
|
+
this.dispatchEvent(bindEvent(this.socket, new CloseEvent("close", event)));
|
|
8126
8132
|
});
|
|
8127
|
-
this.socket[kOnSend] = (
|
|
8133
|
+
this.socket[kOnSend] = (data) => {
|
|
8134
|
+
this.dispatchEvent(
|
|
8135
|
+
bindEvent(
|
|
8136
|
+
this.socket,
|
|
8137
|
+
// Dispatch this as cancelable because "client" connection
|
|
8138
|
+
// re-creates this message event (cannot dispatch the same event).
|
|
8139
|
+
new CancelableMessageEvent("outgoing", {
|
|
8140
|
+
data,
|
|
8141
|
+
origin: this.socket.url,
|
|
8142
|
+
cancelable: true
|
|
8143
|
+
})
|
|
8144
|
+
)
|
|
8145
|
+
);
|
|
8146
|
+
};
|
|
8147
|
+
}
|
|
8148
|
+
addEventListener(type, callback, options) {
|
|
8149
|
+
return super.addEventListener(type, callback, options);
|
|
8150
|
+
}
|
|
8151
|
+
dispatchEvent(event) {
|
|
8152
|
+
return super.dispatchEvent(event);
|
|
8128
8153
|
}
|
|
8129
8154
|
send(data) {
|
|
8130
8155
|
queueMicrotask(() => {
|
|
8131
|
-
|
|
8132
|
-
|
|
8133
|
-
|
|
8134
|
-
|
|
8135
|
-
|
|
8136
|
-
|
|
8137
|
-
|
|
8138
|
-
|
|
8139
|
-
|
|
8140
|
-
|
|
8141
|
-
|
|
8142
|
-
|
|
8143
|
-
|
|
8144
|
-
|
|
8156
|
+
this.socket.dispatchEvent(
|
|
8157
|
+
bindEvent(
|
|
8158
|
+
/**
|
|
8159
|
+
* @note Setting this event's "target" to the
|
|
8160
|
+
* WebSocket override instance is important.
|
|
8161
|
+
* This way it can tell apart original incoming events
|
|
8162
|
+
* (must be forwarded to the transport) from the
|
|
8163
|
+
* mocked message events like the one below
|
|
8164
|
+
* (must be dispatched on the client instance).
|
|
8165
|
+
*/
|
|
8166
|
+
this.socket,
|
|
8167
|
+
new MessageEvent("message", {
|
|
8168
|
+
data,
|
|
8169
|
+
origin: this.socket.url
|
|
8170
|
+
})
|
|
8171
|
+
)
|
|
8145
8172
|
);
|
|
8146
|
-
this.socket.dispatchEvent(message3);
|
|
8147
8173
|
});
|
|
8148
8174
|
}
|
|
8149
8175
|
close(code, reason) {
|
|
@@ -8192,7 +8218,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8192
8218
|
// src/core/ws/webSocketInterceptor.ts
|
|
8193
8219
|
var webSocketInterceptor = new WebSocketInterceptor();
|
|
8194
8220
|
|
|
8195
|
-
// src/core/
|
|
8221
|
+
// src/core/ws/handleWebSocketEvent.ts
|
|
8196
8222
|
function handleWebSocketEvent(options) {
|
|
8197
8223
|
webSocketInterceptor.on("connection", (connection) => {
|
|
8198
8224
|
const handlers = options.getHandlers();
|
|
@@ -8220,9 +8246,6 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8220
8246
|
} else {
|
|
8221
8247
|
options?.onPassthroughConnection(connection);
|
|
8222
8248
|
connection.server.connect();
|
|
8223
|
-
connection.client.addEventListener("message", (event) => {
|
|
8224
|
-
connection.server.send(event.data);
|
|
8225
|
-
});
|
|
8226
8249
|
}
|
|
8227
8250
|
});
|
|
8228
8251
|
}
|
|
@@ -8261,6 +8284,12 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8261
8284
|
}
|
|
8262
8285
|
|
|
8263
8286
|
// src/core/ws/utils/attachWebSocketLogger.ts
|
|
8287
|
+
var colors = {
|
|
8288
|
+
blue: "#3b82f6",
|
|
8289
|
+
green: "#22c55e",
|
|
8290
|
+
red: "#ef4444",
|
|
8291
|
+
orange: "#ff6a33"
|
|
8292
|
+
};
|
|
8264
8293
|
function attachWebSocketLogger(connection) {
|
|
8265
8294
|
const { client, server } = connection;
|
|
8266
8295
|
logConnectionOpen(client);
|
|
@@ -8329,8 +8358,8 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8329
8358
|
function logConnectionOpen(client) {
|
|
8330
8359
|
const publicUrl = toPublicUrl(client.url);
|
|
8331
8360
|
console.groupCollapsed(
|
|
8332
|
-
devUtils.formatMessage(`${getTimestamp()} %c\
|
|
8333
|
-
|
|
8361
|
+
devUtils.formatMessage(`${getTimestamp()} %c\u25B6%c ${publicUrl}`),
|
|
8362
|
+
`color:${colors.blue}`,
|
|
8334
8363
|
"color:inherit"
|
|
8335
8364
|
);
|
|
8336
8365
|
console.log("Client:", client.socket);
|
|
@@ -8343,7 +8372,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8343
8372
|
devUtils.formatMessage(
|
|
8344
8373
|
`${getTimestamp({ milliseconds: true })} %c\u2191%c ${publicData} %c${byteLength}%c`
|
|
8345
8374
|
),
|
|
8346
|
-
|
|
8375
|
+
`color:${colors.green}`,
|
|
8347
8376
|
"color:inherit",
|
|
8348
8377
|
"color:gray;font-weight:normal",
|
|
8349
8378
|
"color:inherit;font-weight:inherit"
|
|
@@ -8358,7 +8387,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8358
8387
|
devUtils.formatMessage(
|
|
8359
8388
|
`${getTimestamp({ milliseconds: true })} %c\u21E1%c ${publicData} %c${byteLength}%c`
|
|
8360
8389
|
),
|
|
8361
|
-
|
|
8390
|
+
`color:${colors.orange}`,
|
|
8362
8391
|
"color:inherit",
|
|
8363
8392
|
"color:gray;font-weight:normal",
|
|
8364
8393
|
"color:inherit;font-weight:inherit"
|
|
@@ -8373,7 +8402,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8373
8402
|
devUtils.formatMessage(
|
|
8374
8403
|
`${getTimestamp({ milliseconds: true })} %c\u2193%c ${publicData} %c${byteLength}%c`
|
|
8375
8404
|
),
|
|
8376
|
-
|
|
8405
|
+
`color:${colors.red}`,
|
|
8377
8406
|
"color:inherit",
|
|
8378
8407
|
"color:gray;font-weight:normal",
|
|
8379
8408
|
"color:inherit;font-weight:inherit"
|
|
@@ -8388,7 +8417,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8388
8417
|
devUtils.formatMessage(
|
|
8389
8418
|
`${getTimestamp({ milliseconds: true })} %c\u21E3%c ${publicData} %c${byteLength}%c`
|
|
8390
8419
|
),
|
|
8391
|
-
|
|
8420
|
+
`color:${colors.orange}`,
|
|
8392
8421
|
"color:inherit",
|
|
8393
8422
|
"color:gray;font-weight:normal",
|
|
8394
8423
|
"color:inherit;font-weight:inherit"
|
|
@@ -8403,7 +8432,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8403
8432
|
devUtils.formatMessage(
|
|
8404
8433
|
`${getTimestamp({ milliseconds: true })} %c\u25A0%c ${publicUrl}`
|
|
8405
8434
|
),
|
|
8406
|
-
|
|
8435
|
+
`color:${colors.blue}`,
|
|
8407
8436
|
"color:inherit"
|
|
8408
8437
|
);
|
|
8409
8438
|
console.log(event);
|
|
@@ -8416,7 +8445,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8416
8445
|
devUtils.formatMessage(
|
|
8417
8446
|
`${getTimestamp({ milliseconds: true })} %c\u21E3%c ${publicData} %c${byteLength}%c`
|
|
8418
8447
|
),
|
|
8419
|
-
|
|
8448
|
+
`color:${colors.green}`,
|
|
8420
8449
|
"color:inherit",
|
|
8421
8450
|
"color:gray;font-weight:normal",
|
|
8422
8451
|
"color:inherit;font-weight:inherit"
|
|
@@ -8431,7 +8460,7 @@ Please consider using a custom "serviceWorker.url" option to point to the actual
|
|
|
8431
8460
|
devUtils.formatMessage(
|
|
8432
8461
|
`${getTimestamp({ milliseconds: true })} %c\xD7%c ${publicUrl}`
|
|
8433
8462
|
),
|
|
8434
|
-
|
|
8463
|
+
`color:${colors.blue}`,
|
|
8435
8464
|
"color:inherit"
|
|
8436
8465
|
);
|
|
8437
8466
|
console.log(event);
|