2021-12-29 23:08:41 +00:00
|
|
|
import express from 'express';
|
|
|
|
import sessions from 'express-session';
|
|
|
|
import cookieParser from 'cookie-parser';
|
|
|
|
import bodyParser from 'body-parser';
|
|
|
|
import { join, dirname } from 'path';
|
|
|
|
import { fileURLToPath } from 'url';
|
|
|
|
import CORS from './cors.js';
|
|
|
|
import CSRF from './csrf.js';
|
|
|
|
import sharedRoutes from '../routes/shared/index.js';
|
|
|
|
import lndRoutes from '../routes/lnd/index.js';
|
2022-05-01 17:35:20 +00:00
|
|
|
import clnRoutes from '../routes/cln/index.js';
|
2021-12-29 23:08:41 +00:00
|
|
|
import eclRoutes from '../routes/eclair/index.js';
|
|
|
|
import { Common } from './common.js';
|
|
|
|
import { Logger } from './logger.js';
|
|
|
|
import { Config } from './config.js';
|
2022-05-01 17:35:20 +00:00
|
|
|
import { CLWSClient } from '../controllers/cln/webSocketClient.js';
|
2021-12-29 23:08:41 +00:00
|
|
|
import { ECLWSClient } from '../controllers/eclair/webSocketClient.js';
|
|
|
|
import { LNDWSClient } from '../controllers/lnd/webSocketClient.js';
|
|
|
|
const ONE_DAY = 1000 * 60 * 60 * 24;
|
|
|
|
export class ExpressApplication {
|
|
|
|
constructor() {
|
|
|
|
this.app = express();
|
|
|
|
this.logger = Logger;
|
|
|
|
this.common = Common;
|
|
|
|
this.config = Config;
|
|
|
|
this.eclWsClient = ECLWSClient;
|
|
|
|
this.clWsClient = CLWSClient;
|
|
|
|
this.lndWsClient = LNDWSClient;
|
|
|
|
this.directoryName = dirname(fileURLToPath(import.meta.url));
|
|
|
|
this.getApp = () => this.app;
|
|
|
|
this.loadConfiguration = () => {
|
|
|
|
this.config.setServerConfiguration();
|
|
|
|
};
|
|
|
|
this.setCORS = () => { CORS.mount(this.app); };
|
|
|
|
this.setCSRF = () => { CSRF.mount(this.app); };
|
|
|
|
this.setApplicationRoutes = () => {
|
2022-01-16 20:55:50 +00:00
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'INFO', fileName: 'App', msg: 'Setting up Application Routes..' });
|
2021-12-29 23:08:41 +00:00
|
|
|
this.app.use(this.common.baseHref + '/api', sharedRoutes);
|
|
|
|
this.app.use(this.common.baseHref + '/api/lnd', lndRoutes);
|
2022-05-01 17:35:20 +00:00
|
|
|
this.app.use(this.common.baseHref + '/api/cln', clnRoutes);
|
2021-12-29 23:08:41 +00:00
|
|
|
this.app.use(this.common.baseHref + '/api/ecl', eclRoutes);
|
|
|
|
this.app.use(this.common.baseHref, express.static(join(this.directoryName, '../..', 'frontend')));
|
|
|
|
this.app.use((req, res, next) => {
|
2022-12-14 05:41:44 +00:00
|
|
|
res.cookie('XSRF-TOKEN', req.csrfToken ? req.csrfToken() : (req.cookies && req.cookies._csrf) ? req.cookies._csrf : ''); // RTL Angular Frontend
|
|
|
|
res.setHeader('XSRF-TOKEN', req.csrfToken ? req.csrfToken() : (req.cookies && req.cookies._csrf) ? req.cookies._csrf : ''); // RTL Quickpay JQuery
|
2021-12-29 23:08:41 +00:00
|
|
|
res.sendFile(join(this.directoryName, '../..', 'frontend', 'index.html'));
|
|
|
|
});
|
2022-09-24 00:35:25 +00:00
|
|
|
this.app.use((err, req, res, next) => {
|
|
|
|
this.handleApplicationErrors(err, res);
|
|
|
|
next();
|
|
|
|
});
|
2022-01-16 20:55:50 +00:00
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'INFO', fileName: 'App', msg: 'Application Routes Set' });
|
2021-12-29 23:08:41 +00:00
|
|
|
};
|
|
|
|
this.handleApplicationErrors = (err, res) => {
|
|
|
|
switch (err.code) {
|
|
|
|
case 'EACCES':
|
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'ERROR', fileName: 'App', msg: 'Server requires elevated privileges' });
|
|
|
|
res.status(406).send('Server requires elevated privileges.');
|
|
|
|
break;
|
|
|
|
case 'EADDRINUSE':
|
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'ERROR', fileName: 'App', msg: 'Server is already in use' });
|
|
|
|
res.status(409).send('Server is already in use.');
|
|
|
|
break;
|
|
|
|
case 'ECONNREFUSED':
|
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'ERROR', fileName: 'App', msg: 'Server is down/locked' });
|
|
|
|
res.status(401).send('Server is down/locked.');
|
|
|
|
break;
|
|
|
|
case 'EBADCSRFTOKEN':
|
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'ERROR', fileName: 'App', msg: 'Invalid CSRF token. Form tempered.' });
|
|
|
|
res.status(403).send('Invalid CSRF token, form tempered.');
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'ERROR', fileName: 'App', msg: 'DEFUALT ERROR', error: err });
|
|
|
|
res.status(400).send(JSON.stringify(err));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
2022-01-16 20:55:50 +00:00
|
|
|
this.logger.log({ selectedNode: this.common.initSelectedNode, level: 'INFO', fileName: 'App', msg: 'Starting Express Application..' });
|
2021-12-29 23:08:41 +00:00
|
|
|
this.app.set('trust proxy', true);
|
|
|
|
this.app.use(sessions({ secret: this.common.secret_key, saveUninitialized: true, cookie: { secure: false, maxAge: ONE_DAY }, resave: false }));
|
|
|
|
this.app.use(cookieParser(this.common.secret_key));
|
|
|
|
this.app.use(bodyParser.json({ limit: '25mb' }));
|
|
|
|
this.app.use(bodyParser.urlencoded({ extended: false, limit: '25mb' }));
|
|
|
|
this.loadConfiguration();
|
|
|
|
this.setCORS();
|
|
|
|
this.setCSRF();
|
|
|
|
this.setApplicationRoutes();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
export default ExpressApplication;
|