f0ckv1/bot.js
2016-09-10 15:34:01 +02:00

52 lines
1.4 KiB
JavaScript

var forever = require('forever-monitor');
var fs = require('fs-extra');
var getDateTimeString = () => {
var date = new Date();
var hour = date.getHours();
hour = (hour < 10 ? "0" : "") + hour;
var min = date.getMinutes();
min = (min < 10 ? "0" : "") + min;
var year = date.getFullYear();
var month = date.getMonth() + 1;
month = (month < 10 ? "0" : "") + month;
var day = date.getDate();
day = (day < 10 ? "0" : "") + day;
return year + "-" + month + "-" + day + "_" + hour + "-" + min;
};
var log_forever = './log/forever_'+getDateTimeString()+'.log';
var log_bot = './log/bot_'+getDateTimeString()+'.log';
var putlog = (msg) => {
fs.appendFileSync(log_forever, msg, 'utf8');
};
var child = new (forever.Monitor)('./src/main.js', {
max: 1,
silent: false,
args: [],
spinSleepTime: 2000,
watch: true,
watchIgnoreDotFiles: true,
watchIgnorePatterns: [
'*.log', 'b/*', 't/*', 'node_modules/*'
],
watchDirectory: __dirname,
logFile: log_bot,
outFile: log_bot,
errFile: log_bot
});
child.on('watch:restart', (info) => {
putlog('Restaring bot because ' + info.stat + ' changed\n');
});
child.on('restart', () => {
putlog('restarting bot for ' + child.times + ' time\n');
});
child.on('start', () => {
putlog('starting bot\n');
});
child.on('exit:code', (code) => {
putlog('detected bot exited with code ' + code + '\n');
child.restart();
});
child.start();