forked from webispy/h2curl
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.js
72 lines (59 loc) · 1.64 KB
/
index.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
require('console-stamp')(console, '[HH:MM:ss.l]');
const http2 = require('http2');
const fs = require('fs')
const url = require('url');
const server = http2.createSecureServer({
key: fs.readFileSync('./server.key'),
cert: fs.readFileSync('./server.crt')
});
const boundary = 'example-boundary-1234';
function pathLongPolling(stream) {
/* send headers */
stream.respond({
':status': 200,
'Content-Type': `multipart/related; boundary=${boundary}`,
});
/* send dummy data */
stream.write(`--${boundary}\r`);
/* stream end after 10 secs */
setTimeout(() => {
console.log('finish the get stream');
stream.end('GET-FINISHED')
}, 10000);
}
function pathPost(stream) {
stream.respond({':status': 200});
stream.on('close', () => {
console.log('event stream closed');
});
stream.on('data', chunk => {
console.log(`post data: ${chunk}`);
});
stream.on('error', code => {
console.log('event stream error:', code);
});
/* stream end after 5 secs */
setTimeout(() => {
console.log('finish the post stream');
stream.end('POST-FINISHED');
}, 5000)
}
server.on('stream', (stream, headers) => {
console.log('Stream:', stream.id, ', Received new request:', headers);
const reqPath = url.parse(headers[':path']);
switch (reqPath.pathname) {
case '/longPolling':
pathLongPolling(stream, headers);
break;
case '/post':
pathPost(stream, headers);
break;
default:
console.log('invalid request:', reqPath.pathname);
break;
}
});
server.on('session', session => {
console.log('---- new session ----', session.socket.remoteAddress);
})
server.listen(8081);