-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
79 lines (64 loc) · 2.74 KB
/
server.js
File metadata and controls
79 lines (64 loc) · 2.74 KB
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
var http = require('http');
var fs = require('fs');
var express = require('express');
var app = express();
var domain = require('domain');
var SetupRequest = require('./api/helpers/setuprequest.js');
var start = process.hrtime();
app.configure(function () {
app.use(function (req, res, next) {
req.options = null;
req.rawBodyRequest = null;
res.header = null;
req.elapsedtime = null;
req.starttime = null;
req.randomkeyid = null;
var requestDomain = domain.create();
requestDomain.add(req);
requestDomain.add(res);
requestDomain.on('error', function (err) {
var precision = 1; // 3 decimal places
var diff = process.hrtime(req.starttime);
var elapsed = ((diff[0] * 1e9) + diff[1]) / 1000000;
req.elapsedtime = elapsed.toFixed(precision);
res.end('{"Error": ' + '"' + err.message + '"' + ',"HasError": true,"Listening": false,"ElapsedTime": ' + '"' + req.elapsedtime + ' ms"}');
requestDomain.dispose();
});
requestDomain.run(next);
});
app.use(app.router);
});
app.get('/telnet', [SetupRequest], function (req, res) {
try {
var net = require('net');
var ipadress = req.query["ip"];
var port = req.query["port"];
var client = net.connect(port, ipadress, function () {
client.write('GET / \r\n \r\n');
client.on('data', function (data) {
var precision = 1; // 3 decimal places
var diff = process.hrtime(req.starttime);
var elapsed = ((diff[0] * 1e9) + diff[1]) / 1000000;
req.elapsedtime = elapsed.toFixed(precision);
req.starttime = process.hrtime(); // reset the timer
res.end('{"Error": null,"HasError": false,"Listening": true,"ElapsedTime": ' + '"' + req.elapsedtime + ' ms"}');
console.log('data:', data.toString());
});
client.on('error', function (err) {
console.log('error:', err.message);
});
client.on('close', function () {
console.log('Connection closed');
});
});
} catch (err2) {
var errormessage = err2.message;
var precision = 1; // 3 decimal places
var diff = process.hrtime(req.starttime);
var elapsed = ((diff[0] * 1e9) + diff[1]) / 1000000;
req.elapsedtime = elapsed.toFixed(precision);
req.starttime = process.hrtime(); // reset the timer
res.end('{"Error": ' + '"' + err2.message + '"' + ',"HasError": true,"Listening": false,"ElapsedTime": ' + '"' + req.elapsedtime + ' ms"}');
}
})
app.listen(process.env.PORT || 8080);