better logging (fixes #100)

This commit is contained in:
Emile Nijssen 2021-11-12 21:20:28 +00:00
parent 5895b986fc
commit c19cb72b6d
2 changed files with 18 additions and 7 deletions

View File

@ -19,7 +19,7 @@ module.exports = class Util {
static promisify(fn) { static promisify(fn) {
// eslint-disable-next-line func-names // eslint-disable-next-line func-names
return function(req, res) { return function (req, res) {
Promise.resolve().then(async () => fn(req, res)) Promise.resolve().then(async () => fn(req, res))
.then(result => { .then(result => {
if (res.headersSent) return; if (res.headersSent) return;
@ -52,9 +52,16 @@ module.exports = class Util {
}; };
} }
static async exec(cmd) { static async exec(cmd, {
log = true,
} = {}) {
if (typeof log === 'string') {
// eslint-disable-next-line no-console
console.log(`$ ${log}`);
} else if (log === true) {
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(`$ ${cmd}`); console.log(`$ ${cmd}`);
}
if (process.platform !== 'linux') { if (process.platform !== 'linux') {
return ''; return '';

View File

@ -37,7 +37,9 @@ module.exports = class WireGuard {
debug('Configuration loaded.'); debug('Configuration loaded.');
} catch (err) { } catch (err) {
const privateKey = await Util.exec('wg genkey'); const privateKey = await Util.exec('wg genkey');
const publicKey = await Util.exec(`echo ${privateKey} | wg pubkey`); const publicKey = await Util.exec(`echo ${privateKey} | wg pubkey`, {
log: `echo ***hidden*** | wg pubkey`
});
const address = WG_DEFAULT_ADDRESS.replace('x', '1'); const address = WG_DEFAULT_ADDRESS.replace('x', '1');
config = { config = {
@ -52,7 +54,7 @@ module.exports = class WireGuard {
} }
await this.__saveConfig(config); await this.__saveConfig(config);
await Util.exec('wg-quick down wg0').catch(() => {}); await Util.exec('wg-quick down wg0').catch(() => { });
await Util.exec('wg-quick up wg0'); await Util.exec('wg-quick up wg0');
await Util.exec(`iptables -t nat -A POSTROUTING -s ${WG_DEFAULT_ADDRESS.replace('x', '0')}/24 -o eth0 -j MASQUERADE`); await Util.exec(`iptables -t nat -A POSTROUTING -s ${WG_DEFAULT_ADDRESS.replace('x', '0')}/24 -o eth0 -j MASQUERADE`);
await Util.exec('iptables -A INPUT -p udp -m udp --dport 51820 -j ACCEPT'); await Util.exec('iptables -A INPUT -p udp -m udp --dport 51820 -j ACCEPT');
@ -127,7 +129,9 @@ AllowedIPs = ${client.address}/32`;
})); }));
// Loop WireGuard status // Loop WireGuard status
const dump = await Util.exec('wg show wg0 dump'); const dump = await Util.exec('wg show wg0 dump', {
log: false,
});
dump dump
.trim() .trim()
.split('\n') .split('\n')