server.js
3.97 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
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
118
119
120
121
122
123
124
125
126
127
128
129
/*
* Copyright © 2016-2018 The Thingsboard Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const config = require('config'),
logger = require('./config/logger')('main'),
express = require('express'),
http = require('http'),
httpProxy = require('http-proxy'),
path = require('path'),
historyApiFallback = require("connect-history-api-fallback");
var server;
(async() => {
try {
logger.info('Starting ThingsBoard Web UI Microservice...');
const bindAddress = config.get('server.address');
const bindPort = config.get('server.port');
const thingsboardHost = config.get('thingsboard.host');
const thingsboardPort = config.get('thingsboard.port');
logger.info('Bind address: %s', bindAddress);
logger.info('Bind port: %s', bindPort);
logger.info('ThingsBoard host: %s', thingsboardHost);
logger.info('ThingsBoard port: %s', thingsboardPort);
var webDir = path.join(__dirname, 'web');
if (typeof process.env.WEB_FOLDER === 'string') {
webDir = path.resolve(process.env.WEB_FOLDER);
}
logger.info('Web folder: %s', webDir);
const app = express();
server = http.createServer(app);
const apiProxy = httpProxy.createProxyServer({
target: {
host: thingsboardHost,
port: thingsboardPort
}
});
apiProxy.on('error', function (err, req, res) {
logger.warn('API proxy error: %s', err.message);
res.writeHead(500);
if (err.code && err.code === 'ECONNREFUSED') {
res.end('Unable to connect to ThingsBoard server.');
} else {
res.end('Thingsboard server connection error: ' + err.code ? err.code : '');
}
});
const root = path.join(webDir, 'public');
const staticDir = path.join(root, 'static');
app.all('/api/*', (req, res) => {
logger.info(req.method + ' ' + req.originalUrl);
apiProxy.web(req, res);
});
app.all('/static/rulenode/*', (req, res) => {
apiProxy.web(req, res);
});
app.use(historyApiFallback());
app.use('/static', express.static(staticDir));
app.get('*', (req, res) => {
apiProxy.web(req, res);
});
server.on('upgrade', (req, socket, head) => {
apiProxy.ws(req, socket, head);
});
server.listen(bindPort, bindAddress, (error) => {
if (error) {
logger.error('Failed to start ThingsBoard Web UI Microservice: %s', e.message);
logger.error(error.stack);
exit(-1);
} else {
logger.info('==> 🌎 Listening on port %s.', bindPort);
logger.info('Started ThingsBoard Web UI Microservice.');
}
});
} catch (e) {
logger.error('Failed to start ThingsBoard Web UI Microservice: %s', e.message);
logger.error(e.stack);
exit(-1);
}
})();
process.on('exit', function () {
exit(0);
});
function exit(status) {
logger.info('Exiting with status: %d ...', status);
if (server) {
logger.info('Stopping HTTP Server...');
var _server = server;
server = null;
_server.close(() => {
logger.info('HTTP Server stopped.');
process.exit(status);
});
} else {
process.exit(status);
}
}