2021-06-18 15:14:31 +02:00
|
|
|
/**
|
|
|
|
* Note: The app must first be built (yarn build) before this script is run
|
|
|
|
* This is the main entry point for the application, a simple server that
|
|
|
|
* runs some checks, and then serves up the app from the ./dist directory
|
|
|
|
* Also includes some routes for status checks/ ping and config saving
|
|
|
|
* */
|
2019-09-01 14:38:13 +02:00
|
|
|
|
2021-06-18 15:14:31 +02:00
|
|
|
/* Include required node dependencies */
|
|
|
|
const serveStatic = require('serve-static');
|
|
|
|
const connect = require('connect');
|
2021-06-04 20:57:43 +02:00
|
|
|
const util = require('util');
|
|
|
|
const dns = require('dns');
|
|
|
|
const os = require('os');
|
2021-06-18 19:01:42 +02:00
|
|
|
const bodyParser = require('body-parser');
|
2021-06-04 20:57:43 +02:00
|
|
|
|
2021-07-25 18:43:47 +02:00
|
|
|
/* Kick of some basic checks */
|
|
|
|
require('./services/update-checker'); // Checks if there are any updates available, prints message
|
|
|
|
require('./services/config-validator'); // Include and kicks off the config file validation script
|
|
|
|
|
2021-09-17 23:40:39 +02:00
|
|
|
/* Include route handlers for API endpoints */
|
2021-09-18 00:51:02 +02:00
|
|
|
const statusCheck = require('./services/status-check'); // Used by the status check feature, uses GET
|
2021-06-18 19:01:42 +02:00
|
|
|
const saveConfig = require('./services/save-config'); // Saves users new conf.yml to file-system
|
2021-06-19 20:21:32 +02:00
|
|
|
const rebuild = require('./services/rebuild-app'); // A script to programmatically trigger a build
|
2021-06-14 21:42:02 +02:00
|
|
|
|
2021-09-17 23:40:39 +02:00
|
|
|
/* Helper functions, and default config */
|
|
|
|
const printMessage = require('./services/print-message'); // Function to print welcome msg on start
|
|
|
|
const ENDPOINTS = require('./src/utils/defaults').serviceEndpoints; // API endpoint URL paths
|
|
|
|
|
2021-06-18 15:14:31 +02:00
|
|
|
/* Checks if app is running within a container, from env var */
|
2021-06-10 20:46:46 +02:00
|
|
|
const isDocker = !!process.env.IS_DOCKER;
|
|
|
|
|
|
|
|
/* Checks env var for port. If undefined, will use Port 80 for Docker, or 4000 for metal */
|
2021-06-11 21:42:32 +02:00
|
|
|
const port = process.env.PORT || (isDocker ? 80 : 4000);
|
2019-09-01 14:38:13 +02:00
|
|
|
|
2021-06-18 15:14:31 +02:00
|
|
|
/* Attempts to get the users local IP, used as part of welcome message */
|
2021-06-04 20:57:43 +02:00
|
|
|
const getLocalIp = () => {
|
|
|
|
const dnsLookup = util.promisify(dns.lookup);
|
|
|
|
return dnsLookup(os.hostname());
|
2021-06-11 16:23:25 +02:00
|
|
|
};
|
2021-06-04 20:57:43 +02:00
|
|
|
|
2021-06-18 15:14:31 +02:00
|
|
|
/* Gets the users local IP and port, then calls to print welcome message */
|
2021-06-11 16:23:25 +02:00
|
|
|
const printWelcomeMessage = () => {
|
|
|
|
getLocalIp().then(({ address }) => {
|
|
|
|
const ip = address || 'localhost';
|
2021-06-18 15:14:31 +02:00
|
|
|
console.log(printMessage(ip, port, isDocker)); // eslint-disable-line no-console
|
2021-06-11 16:23:25 +02:00
|
|
|
});
|
|
|
|
};
|
2021-06-04 20:57:43 +02:00
|
|
|
|
2021-06-19 20:21:32 +02:00
|
|
|
/* Just console.warns an error */
|
2021-06-18 15:14:31 +02:00
|
|
|
const printWarning = (msg, error) => {
|
|
|
|
console.warn(`\x1b[103m\x1b[34m${msg}\x1b[0m\n`, error || ''); // eslint-disable-line no-console
|
|
|
|
};
|
|
|
|
|
2021-06-18 19:01:42 +02:00
|
|
|
/* A middleware function for Connect, that filters requests based on method type */
|
|
|
|
const method = (m, mw) => (req, res, next) => (req.method === m ? mw(req, res, next) : next());
|
|
|
|
|
2019-09-01 14:38:13 +02:00
|
|
|
try {
|
|
|
|
connect()
|
2021-06-18 19:01:42 +02:00
|
|
|
.use(bodyParser.json())
|
2021-06-18 15:14:31 +02:00
|
|
|
// Serves up the main built application to the root
|
|
|
|
.use(serveStatic(`${__dirname}/dist`))
|
|
|
|
// During build, a custom page will be served before the app is available
|
|
|
|
.use(serveStatic(`${__dirname}/public`, { index: 'default.html' }))
|
2021-09-18 00:51:02 +02:00
|
|
|
// GET endpoint to run status of a given URL with GET request
|
2021-09-17 23:40:39 +02:00
|
|
|
.use(ENDPOINTS.statusCheck, (req, res) => {
|
2021-06-14 21:42:02 +02:00
|
|
|
try {
|
2021-09-17 23:40:39 +02:00
|
|
|
statusCheck(req.url, async (results) => {
|
2021-06-14 21:42:02 +02:00
|
|
|
await res.end(results);
|
|
|
|
});
|
2021-09-18 00:51:02 +02:00
|
|
|
} catch (e) {
|
|
|
|
printWarning(`Error running status check for ${req.url}\n`, e);
|
|
|
|
}
|
|
|
|
})
|
2021-06-18 19:01:42 +02:00
|
|
|
// POST Endpoint used to save config, by writing conf.yml to disk
|
2021-09-17 23:40:39 +02:00
|
|
|
.use(ENDPOINTS.save, method('POST', (req, res) => {
|
2021-06-19 14:47:10 +02:00
|
|
|
try {
|
2021-09-18 00:51:02 +02:00
|
|
|
saveConfig(req.body, (results) => { res.end(results); });
|
2021-06-19 14:47:10 +02:00
|
|
|
} catch (e) {
|
|
|
|
res.end(JSON.stringify({ success: false, message: e }));
|
|
|
|
}
|
2021-06-18 19:01:42 +02:00
|
|
|
}))
|
2021-06-19 20:21:32 +02:00
|
|
|
// GET endpoint to trigger a build, and respond with success status and output
|
2021-09-17 23:40:39 +02:00
|
|
|
.use(ENDPOINTS.rebuild, (req, res) => {
|
2021-06-19 20:21:32 +02:00
|
|
|
rebuild().then((response) => {
|
|
|
|
res.end(JSON.stringify(response));
|
|
|
|
}).catch((response) => {
|
|
|
|
res.end(JSON.stringify(response));
|
|
|
|
});
|
|
|
|
})
|
2021-06-18 15:14:31 +02:00
|
|
|
// Finally, initialize the server then print welcome message
|
2021-06-04 20:57:43 +02:00
|
|
|
.listen(port, () => {
|
2021-06-18 15:14:31 +02:00
|
|
|
try { printWelcomeMessage(); } catch (e) { printWarning('Dashy is Starting...'); }
|
2021-06-04 20:57:43 +02:00
|
|
|
});
|
2019-09-01 14:38:13 +02:00
|
|
|
} catch (error) {
|
2021-06-19 20:21:32 +02:00
|
|
|
printWarning('Sorry, a critical error occurred ', error);
|
2019-07-23 17:03:59 +02:00
|
|
|
}
|