-
Notifications
You must be signed in to change notification settings - Fork 583
/
Copy pathUpgradeAsync.js
80 lines (71 loc) · 2.47 KB
/
UpgradeAsync.js
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
/* A quite detailed WebSockets upgrade example "async" */
const uWS = require('../dist/uws.js');
const port = 9001;
const app = uWS./*SSL*/App({
key_file_name: 'misc/key.pem',
cert_file_name: 'misc/cert.pem',
passphrase: '1234'
}).ws('/*', {
/* Options */
compression: uWS.SHARED_COMPRESSOR,
maxPayloadLength: 16 * 1024 * 1024,
idleTimeout: 10,
/* Handlers */
upgrade: (res, req, context) => {
console.log('An Http connection wants to become WebSocket, URL: ' + req.getUrl() + '!');
/* Keep track of abortions */
const upgradeAborted = {aborted: false};
/* You MUST copy data out of req here, as req is only valid within this immediate callback */
const url = req.getUrl();
const secWebSocketKey = req.getHeader('sec-websocket-key');
const secWebSocketProtocol = req.getHeader('sec-websocket-protocol');
const secWebSocketExtensions = req.getHeader('sec-websocket-extensions');
/* Simulate doing "async" work before upgrading */
setTimeout(() => {
console.log("We are now done with our async task, let's upgrade the WebSocket!");
if (upgradeAborted.aborted) {
console.log("Ouch! Client disconnected before we could upgrade it!");
/* You must not upgrade now */
return;
}
/* Cork any async response including upgrade */
res.cork(() => {
/* This immediately calls open handler, you must not use res after this call */
res.upgrade(
{ url: url },
/* Use our copies here */
secWebSocketKey,
secWebSocketProtocol,
secWebSocketExtensions,
context
);
});
}, 1000);
/* You MUST register an abort handler to know if the upgrade was aborted by peer */
res.onAborted(() => {
/* We can simply signal that we were aborted */
upgradeAborted.aborted = true;
});
},
open: (ws) => {
console.log('A WebSocket connected with URL: ' + ws.url);
},
message: (ws, message, isBinary) => {
/* Ok is false if backpressure was built up, wait for drain */
let ok = ws.send(message, isBinary);
},
drain: (ws) => {
console.log('WebSocket backpressure: ' + ws.getBufferedAmount());
},
close: (ws, code, message) => {
console.log('WebSocket closed');
}
}).any('/*', (res, req) => {
res.end('Nothing to see here!');
}).listen(port, (token) => {
if (token) {
console.log('Listening to port ' + port);
} else {
console.log('Failed to listen to port ' + port);
}
});