mirror of
https://github.com/Lissy93/dashy.git
synced 2025-07-27 07:34:43 +02:00
Refactors the main server.js, and moves welcome msg to separate file
This commit is contained in:
parent
ca3d171e47
commit
856b9eb3c6
84
server.js
84
server.js
@ -1,84 +1,66 @@
|
|||||||
/* eslint-disable no-console */
|
/**
|
||||||
/* This is a simple Node.js http server, that is used to serve up the contents of ./dist */
|
* Note: The app must first be built (yarn build) before this script is run
|
||||||
const connect = require('connect');
|
* This is the main entry point for the application, a simple server that
|
||||||
const serveStatic = require('serve-static');
|
* runs some checks, and then serves up the app from the ./dist directory
|
||||||
|
* Also includes some routes for status checks/ ping and config saving
|
||||||
|
* */
|
||||||
|
|
||||||
|
/* Include required node dependencies */
|
||||||
|
const serveStatic = require('serve-static');
|
||||||
|
const connect = require('connect');
|
||||||
const util = require('util');
|
const util = require('util');
|
||||||
const dns = require('dns');
|
const dns = require('dns');
|
||||||
const os = require('os');
|
const os = require('os');
|
||||||
|
|
||||||
require('./src/utils/ConfigValidator');
|
/* Include helper functions */
|
||||||
|
const pingUrl = require('./services/ping'); // Used by the status check feature, to ping services
|
||||||
const pingUrl = require('./services/ping');
|
const printMessage = require('./services/print-message'); // Function to print welcome msg on start
|
||||||
|
require('./src/utils/ConfigValidator'); // Include and kicks off the config file validation script
|
||||||
|
|
||||||
|
/* Checks if app is running within a container, from env var */
|
||||||
const isDocker = !!process.env.IS_DOCKER;
|
const isDocker = !!process.env.IS_DOCKER;
|
||||||
|
|
||||||
/* Checks env var for port. If undefined, will use Port 80 for Docker, or 4000 for metal */
|
/* Checks env var for port. If undefined, will use Port 80 for Docker, or 4000 for metal */
|
||||||
const port = process.env.PORT || (isDocker ? 80 : 4000);
|
const port = process.env.PORT || (isDocker ? 80 : 4000);
|
||||||
|
|
||||||
|
/* Attempts to get the users local IP, used as part of welcome message */
|
||||||
const getLocalIp = () => {
|
const getLocalIp = () => {
|
||||||
const dnsLookup = util.promisify(dns.lookup);
|
const dnsLookup = util.promisify(dns.lookup);
|
||||||
return dnsLookup(os.hostname());
|
return dnsLookup(os.hostname());
|
||||||
};
|
};
|
||||||
|
|
||||||
const overComplicatedMessage = (ip) => {
|
/* Gets the users local IP and port, then calls to print welcome message */
|
||||||
let msg = '';
|
|
||||||
const chars = {
|
|
||||||
RESET: '\x1b[0m',
|
|
||||||
CYAN: '\x1b[36m',
|
|
||||||
GREEN: '\x1b[32m',
|
|
||||||
BLUE: '\x1b[34m',
|
|
||||||
BRIGHT: '\x1b[1m',
|
|
||||||
BR: '\n',
|
|
||||||
};
|
|
||||||
const stars = (count) => new Array(count).fill('*').join('');
|
|
||||||
const line = (count) => new Array(count).fill('━').join('');
|
|
||||||
const blanks = (count) => new Array(count).fill(' ').join('');
|
|
||||||
if (isDocker) {
|
|
||||||
const containerId = process.env.HOSTNAME || undefined;
|
|
||||||
msg = `${chars.BLUE}${stars(91)}${chars.BR}${chars.RESET}`
|
|
||||||
+ `${chars.CYAN}Welcome to Dashy! 🚀${chars.RESET}${chars.BR}`
|
|
||||||
+ `${chars.GREEN}Your new dashboard is now up and running `
|
|
||||||
+ `${containerId ? `in container ID ${containerId}` : 'with Docker'}${chars.BR}`
|
|
||||||
+ `${chars.GREEN}After updating your config file, run `
|
|
||||||
+ `'${chars.BRIGHT}docker exec -it ${containerId || '[container-id]'} yarn build`
|
|
||||||
+ `${chars.RESET}${chars.GREEN}' to rebuild${chars.BR}`
|
|
||||||
+ `${chars.BLUE}${stars(91)}${chars.BR}${chars.RESET}`;
|
|
||||||
} else {
|
|
||||||
msg = `${chars.GREEN}┏${line(75)}┓${chars.BR}`
|
|
||||||
+ `┃ ${chars.CYAN}Welcome to Dashy! 🚀${blanks(55)}${chars.GREEN}┃${chars.BR}`
|
|
||||||
+ `┃ ${chars.CYAN}Your new dashboard is now up and running at ${chars.BRIGHT}`
|
|
||||||
+ `http://${ip}:${port}${chars.RESET}${blanks(18 - ip.length)}${chars.GREEN}┃${chars.BR}`
|
|
||||||
+ `┃ ${chars.CYAN}After updating your config file, run '${chars.BRIGHT}yarn build`
|
|
||||||
+ `${chars.RESET}${chars.CYAN}' to rebuild the app${blanks(6)}${chars.GREEN}┃${chars.BR}`
|
|
||||||
+ `┗${line(75)}┛${chars.BR}${chars.BR}`;
|
|
||||||
}
|
|
||||||
return msg;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* eslint no-console: 0 */
|
|
||||||
const printWelcomeMessage = () => {
|
const printWelcomeMessage = () => {
|
||||||
getLocalIp().then(({ address }) => {
|
getLocalIp().then(({ address }) => {
|
||||||
const ip = address || 'localhost';
|
const ip = address || 'localhost';
|
||||||
console.log(overComplicatedMessage(ip));
|
console.log(printMessage(ip, port, isDocker)); // eslint-disable-line no-console
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const printWarning = (msg, error) => {
|
||||||
|
console.warn(`\x1b[103m\x1b[34m${msg}\x1b[0m\n`, error || ''); // eslint-disable-line no-console
|
||||||
|
};
|
||||||
|
|
||||||
try {
|
try {
|
||||||
connect()
|
connect()
|
||||||
.use(serveStatic(`${__dirname}/dist`)) /* Serves up the main built application to the root */
|
// Serves up the main built application to the root
|
||||||
.use(serveStatic(`${__dirname}/public`, { index: 'default.html' })) /* During build, a custom page will be served */
|
.use(serveStatic(`${__dirname}/dist`))
|
||||||
.use('/ping', (req, res) => { /* This root returns the status of a given service - used for uptime monitoring */
|
// During build, a custom page will be served before the app is available
|
||||||
|
.use(serveStatic(`${__dirname}/public`, { index: 'default.html' }))
|
||||||
|
// This root returns the status of a given service - used for uptime monitoring
|
||||||
|
.use('/ping', (req, res) => {
|
||||||
try {
|
try {
|
||||||
pingUrl(req.url, async (results) => {
|
pingUrl(req.url, async (results) => {
|
||||||
await res.end(results);
|
await res.end(results);
|
||||||
});
|
});
|
||||||
// next();
|
} catch (e) {
|
||||||
} catch (e) { console.warn(`Error running ping check for ${req.url}\n`, e); }
|
printWarning(`Error running ping check for ${req.url}\n`, e);
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
// Finally, initialize the server then print welcome message
|
||||||
.listen(port, () => {
|
.listen(port, () => {
|
||||||
try { printWelcomeMessage(); } catch (e) { console.log('Dashy is Starting...'); }
|
try { printWelcomeMessage(); } catch (e) { printWarning('Dashy is Starting...'); }
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.log('Sorry, an error occurred ', error);
|
printWarning('Sorry, an error occurred ', error);
|
||||||
}
|
}
|
||||||
|
42
services/print-message.js
Normal file
42
services/print-message.js
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/**
|
||||||
|
* A function that prints a welcome message to the user when they start the app
|
||||||
|
* Contains essential info about restarting and managing the container or service
|
||||||
|
* @param String ip: The users local IP address
|
||||||
|
* @param Integer port: the port number the app is running at
|
||||||
|
* @param Boolean isDocker: whether or not the app is being run within a container
|
||||||
|
* @returns A string formatted for the terminal
|
||||||
|
*/
|
||||||
|
module.exports = (ip, port, isDocker) => {
|
||||||
|
let msg = '';
|
||||||
|
const chars = {
|
||||||
|
RESET: '\x1b[0m',
|
||||||
|
CYAN: '\x1b[36m',
|
||||||
|
GREEN: '\x1b[32m',
|
||||||
|
BLUE: '\x1b[34m',
|
||||||
|
BRIGHT: '\x1b[1m',
|
||||||
|
BR: '\n',
|
||||||
|
};
|
||||||
|
const stars = (count) => new Array(count).fill('*').join('');
|
||||||
|
const line = (count) => new Array(count).fill('━').join('');
|
||||||
|
const blanks = (count) => new Array(count).fill(' ').join('');
|
||||||
|
if (isDocker) {
|
||||||
|
const containerId = process.env.HOSTNAME || undefined;
|
||||||
|
msg = `${chars.BLUE}${stars(91)}${chars.BR}${chars.RESET}`
|
||||||
|
+ `${chars.CYAN}Welcome to Dashy! 🚀${chars.RESET}${chars.BR}`
|
||||||
|
+ `${chars.GREEN}Your new dashboard is now up and running `
|
||||||
|
+ `${containerId ? `in container ID ${containerId}` : 'with Docker'}${chars.BR}`
|
||||||
|
+ `${chars.GREEN}After updating your config file, run `
|
||||||
|
+ `'${chars.BRIGHT}docker exec -it ${containerId || '[container-id]'} yarn build`
|
||||||
|
+ `${chars.RESET}${chars.GREEN}' to rebuild${chars.BR}`
|
||||||
|
+ `${chars.BLUE}${stars(91)}${chars.BR}${chars.RESET}`;
|
||||||
|
} else {
|
||||||
|
msg = `${chars.GREEN}┏${line(75)}┓${chars.BR}`
|
||||||
|
+ `┃ ${chars.CYAN}Welcome to Dashy! 🚀${blanks(55)}${chars.GREEN}┃${chars.BR}`
|
||||||
|
+ `┃ ${chars.CYAN}Your new dashboard is now up and running at ${chars.BRIGHT}`
|
||||||
|
+ `http://${ip}:${port}${chars.RESET}${blanks(18 - ip.length)}${chars.GREEN}┃${chars.BR}`
|
||||||
|
+ `┃ ${chars.CYAN}After updating your config file, run '${chars.BRIGHT}yarn build`
|
||||||
|
+ `${chars.RESET}${chars.CYAN}' to rebuild the app${blanks(6)}${chars.GREEN}┃${chars.BR}`
|
||||||
|
+ `┗${line(75)}┛${chars.BR}${chars.BR}`;
|
||||||
|
}
|
||||||
|
return msg;
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user