2022-07-01 19:03:29 +03:00
|
|
|
///
|
|
|
|
|
/// Copyright © 2016-2022 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.
|
|
|
|
|
///
|
|
|
|
|
|
2018-10-02 17:42:09 +03:00
|
|
|
/*
|
2022-01-17 14:07:46 +02:00
|
|
|
* Copyright © 2016-2022 The Thingsboard Authors
|
2018-10-02 17:42:09 +03:00
|
|
|
*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
import express from 'express';
|
|
|
|
|
import config from 'config';
|
|
|
|
|
import { _logger} from './config/logger';
|
|
|
|
|
import path from 'path';
|
|
|
|
|
import http, { ServerResponse } from 'http';
|
|
|
|
|
import httpProxy from 'http-proxy';
|
|
|
|
|
import compression from 'compression';
|
|
|
|
|
import historyApiFallback from 'connect-history-api-fallback';
|
|
|
|
|
|
|
|
|
|
const logger = _logger('main');
|
|
|
|
|
|
|
|
|
|
let server: http.Server | null;
|
2018-10-02 17:42:09 +03:00
|
|
|
|
|
|
|
|
(async() => {
|
|
|
|
|
try {
|
|
|
|
|
logger.info('Starting ThingsBoard Web UI Microservice...');
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
const bindAddress: string = config.get('server.address');
|
|
|
|
|
const bindPort = Number(config.get('server.port'));
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
const thingsboardEnableProxy: string = config.get('thingsboard.enableProxy');
|
2018-11-07 19:09:55 +02:00
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
const thingsboardHost: string = config.get('thingsboard.host');
|
|
|
|
|
const thingsboardPort = Number(config.get('thingsboard.port'));
|
2018-10-02 17:42:09 +03:00
|
|
|
|
|
|
|
|
logger.info('Bind address: %s', bindAddress);
|
|
|
|
|
logger.info('Bind port: %s', bindPort);
|
2018-11-07 19:09:55 +02:00
|
|
|
logger.info('ThingsBoard Enable Proxy: %s', thingsboardEnableProxy);
|
2018-10-02 17:42:09 +03:00
|
|
|
logger.info('ThingsBoard host: %s', thingsboardHost);
|
|
|
|
|
logger.info('ThingsBoard port: %s', thingsboardPort);
|
|
|
|
|
|
2018-11-07 19:09:55 +02:00
|
|
|
const useApiProxy = thingsboardEnableProxy === "true";
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
let webDir = path.join(__dirname, 'web');
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
if (typeof process.env.WEB_FOLDER !== 'undefined') {
|
2018-10-02 17:42:09 +03:00
|
|
|
webDir = path.resolve(process.env.WEB_FOLDER);
|
|
|
|
|
}
|
|
|
|
|
logger.info('Web folder: %s', webDir);
|
|
|
|
|
|
|
|
|
|
const app = express();
|
|
|
|
|
server = http.createServer(app);
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
let apiProxy: httpProxy;
|
2018-11-07 19:09:55 +02:00
|
|
|
if (useApiProxy) {
|
2018-11-28 16:46:49 +02:00
|
|
|
apiProxy = httpProxy.createProxyServer({
|
2018-11-07 19:09:55 +02:00
|
|
|
target: {
|
|
|
|
|
host: thingsboardHost,
|
|
|
|
|
port: thingsboardPort
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
apiProxy.on('error', function (err, req, res) {
|
|
|
|
|
logger.warn('API proxy error: %s', err.message);
|
2022-07-01 19:03:29 +03:00
|
|
|
if (res instanceof ServerResponse) {
|
|
|
|
|
res.writeHead(500);
|
|
|
|
|
const error = err as any;
|
|
|
|
|
if (error.code && error.code === 'ECONNREFUSED') {
|
|
|
|
|
res.end('Unable to connect to ThingsBoard server.');
|
|
|
|
|
} else {
|
|
|
|
|
res.end('Thingsboard server connection error: ' + error.code ? error.code : '');
|
|
|
|
|
}
|
2018-11-07 19:09:55 +02:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
app.all('/api/*', (req, res) => {
|
2020-02-26 20:43:39 +02:00
|
|
|
logger.debug(req.method + ' ' + req.originalUrl);
|
|
|
|
|
apiProxy.web(req, res);
|
2018-11-07 19:09:55 +02:00
|
|
|
});
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2018-11-07 19:09:55 +02:00
|
|
|
app.all('/static/rulenode/*', (req, res) => {
|
2020-02-26 20:43:39 +02:00
|
|
|
apiProxy.web(req, res);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
server.on('upgrade', (req, socket, head) => {
|
|
|
|
|
apiProxy.ws(req, socket, head);
|
2018-11-07 19:09:55 +02:00
|
|
|
});
|
|
|
|
|
}
|
2018-10-02 17:42:09 +03:00
|
|
|
|
|
|
|
|
app.use(historyApiFallback());
|
2018-11-28 16:46:49 +02:00
|
|
|
app.use(compression());
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2018-11-07 19:09:55 +02:00
|
|
|
const root = path.join(webDir, 'public');
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2018-11-07 19:09:55 +02:00
|
|
|
app.use(express.static(root));
|
2018-10-02 17:42:09 +03:00
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
server.listen(bindPort, bindAddress, () => {
|
|
|
|
|
logger.info('==> 🌎 Listening on port %s.', bindPort);
|
|
|
|
|
logger.info('Started ThingsBoard Web UI Microservice.');
|
|
|
|
|
}).on('error', (error) => {
|
|
|
|
|
logger.error('Failed to start ThingsBoard Web UI Microservice: %s', error.message);
|
|
|
|
|
logger.error(error.stack);
|
|
|
|
|
exit(-1);
|
2018-10-02 17:42:09 +03:00
|
|
|
});
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
} catch (e: any) {
|
2018-10-02 17:42:09 +03:00
|
|
|
logger.error('Failed to start ThingsBoard Web UI Microservice: %s', e.message);
|
|
|
|
|
logger.error(e.stack);
|
|
|
|
|
exit(-1);
|
|
|
|
|
}
|
|
|
|
|
})();
|
|
|
|
|
|
|
|
|
|
process.on('exit', function () {
|
|
|
|
|
exit(0);
|
|
|
|
|
});
|
|
|
|
|
|
2022-07-01 19:03:29 +03:00
|
|
|
function exit(status: number) {
|
2018-10-02 17:42:09 +03:00
|
|
|
logger.info('Exiting with status: %d ...', status);
|
|
|
|
|
if (server) {
|
|
|
|
|
logger.info('Stopping HTTP Server...');
|
2022-07-01 19:03:29 +03:00
|
|
|
const _server = server;
|
2018-10-02 17:42:09 +03:00
|
|
|
server = null;
|
|
|
|
|
_server.close(() => {
|
|
|
|
|
logger.info('HTTP Server stopped.');
|
|
|
|
|
process.exit(status);
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
process.exit(status);
|
|
|
|
|
}
|
|
|
|
|
}
|