1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
const {
FrontClassWithSpec,
registerFront,
} = require("resource://devtools/shared/protocol.js");
const {
webSocketSpec,
} = require("resource://devtools/shared/specs/websocket.js");
/**
* A WebSocketFront is used as a front end for the WebSocketActor that is
* created on the server, hiding implementation details.
*/
class WebSocketFront extends FrontClassWithSpec(webSocketSpec) {
constructor(client, targetFront, parentFront) {
super(client, targetFront, parentFront);
this._onWebSocketOpened = this._onWebSocketOpened.bind(this);
this._onWebSocketClosed = this._onWebSocketClosed.bind(this);
this._onFrameSent = this._onFrameSent.bind(this);
this._onFrameReceived = this._onFrameReceived.bind(this);
// Attribute name from which to retrieve the actorID
// out of the target actor's form
this.formAttributeName = "webSocketActor";
this.on("serverWebSocketOpened", this._onWebSocketOpened);
this.on("serverWebSocketClosed", this._onWebSocketClosed);
this.on("serverFrameSent", this._onFrameSent);
this.on("serverFrameReceived", this._onFrameReceived);
}
/**
* Close the WebSocketFront.
*
*/
destroy() {
this.off("serverWebSocketOpened");
this.off("serverWebSocketClosed");
this.off("serverFrameSent");
this.off("serverFrameReceived");
return super.destroy();
}
/**
* The "webSocketOpened" message type handler. We redirect any message to
* the UI for displaying.
*
* @private
* @param number httpChannelId
* Channel ID of the websocket connection.
* @param string effectiveURI
* URI of the page.
* @param string protocols
* WebSocket procotols.
* @param string extensions
*/
async _onWebSocketOpened(httpChannelId, effectiveURI, protocols, extensions) {
this.emit(
"webSocketOpened",
httpChannelId,
effectiveURI,
protocols,
extensions
);
}
/**
* The "webSocketClosed" message type handler. We redirect any message to
* the UI for displaying.
*
* @private
* @param number httpChannelId
* @param boolean wasClean
* @param number code
* @param string reason
*/
async _onWebSocketClosed(httpChannelId, wasClean, code, reason) {
this.emit("webSocketClosed", httpChannelId, wasClean, code, reason);
}
/**
* The "frameReceived" message type handler. We redirect any message to
* the UI for displaying.
*
* @private
* @param string httpChannelId
* Channel ID of the websocket connection.
* @param object data
* The data received from the server.
*/
async _onFrameReceived(httpChannelId, data) {
this.emit("frameReceived", httpChannelId, data);
}
/**
* The "frameSent" message type handler. We redirect any message to
* the UI for displaying.
*
* @private
* @param string httpChannelId
* Channel ID of the websocket connection.
* @param object data
* The data received from the server.
*/
async _onFrameSent(httpChannelId, data) {
this.emit("frameSent", httpChannelId, data);
}
}
exports.WebSocketFront = WebSocketFront;
registerFront(WebSocketFront);
|