47 lines
1.2 KiB
JavaScript
47 lines
1.2 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 = './log/bot_'+getDateTimeString()+'.log';
|
||
|
var putlog = (msg) => {
|
||
|
fs.appendFileSync(log, msg, 'utf8');
|
||
|
};
|
||
|
|
||
|
var child = new (forever.Monitor)('./src/main.js', {
|
||
|
max: 3,
|
||
|
silent: false,
|
||
|
args: []
|
||
|
});
|
||
|
|
||
|
child.on('watch:restart', (info) => {
|
||
|
putlog('Restaring bot because ' + info.file + ' 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.on('stdout', (data) => {
|
||
|
putlog(data);
|
||
|
});
|
||
|
child.on('stderr', (data) => {
|
||
|
putlog(data);
|
||
|
});
|
||
|
|
||
|
child.start();
|