//load database var Datastore = require('nedb'); var db = new Datastore({ filename: __dirname + '/crontabs/crontab.db' }); db.loadDatabase(function (err) { }); var exec = require('child_process').exec; var fs = require('fs'); var cron_parser = require("cron-parser"); var os = require("os"); exports.log_folder = __dirname + '/crontabs/logs'; exports.env_file = __dirname + '/crontabs/env.db'; crontab = function(name, command, schedule, stopped, logging){ var data = {}; data.name = name; data.command = command; data.schedule = schedule; if(stopped !== null) { data.stopped = stopped; } data.timestamp = (new Date()).toString(); data.logging = logging; return data; }; exports.create_new = function(name, command, schedule, logging){ var tab = crontab(name, command, schedule, false, logging); tab.created = new Date().valueOf(); db.insert(tab); }; exports.update = function(data){ db.update({_id: data._id}, crontab(data.name, data.command, data.schedule, null, data.logging)); }; exports.status = function(_id, stopped){ db.update({_id: _id},{$set: {stopped: stopped}}); }; exports.remove = function(_id){ db.remove({_id: _id}, {}); }; exports.crontabs = function(callback){ db.find({}).sort({ created: -1 }).exec(function(err, docs){ for(var i=0; i/tmp/.log|| {if test -f /tmp/; then date >> ; cat /tmp/.log >> ; rm /tmp.log } crontab_string += tab.schedule + " { " + tab.command + " } 2> " + tmp_log +"; if test -f " + tmp_log +"; then date >> " + log_file + "; cat " + tmp_log + " >> " + log_file + "; rm " + tmp_log + "; fi \n"; } else crontab_string += tab.schedule + " " + tab.command + "\n"; } }); fs.writeFile(exports.env_file, env_vars); fs.writeFile("/tmp/crontab", crontab_string, function(err) { exec("crontab /tmp/crontab"); }); }); }; exports.get_backup_names = function(){ var backups = []; fs.readdirSync(__dirname + '/crontabs').forEach(function(file){ // file name begins with backup if(file.indexOf("backup") == 0){ backups.push(file); } }); // Sort by date. Newest on top for(var i=0; i Tj){ var temp = backups[i]; backups[i] = backups[j]; backups[j] = temp; } } } return backups; }; exports.backup = function(){ //TODO check if it failed fs.createReadStream( __dirname + '/crontabs/crontab.db').pipe(fs.createWriteStream( __dirname + '/crontabs/backup ' + (new Date()).toString().replace("+", " ") + '.db')); }; exports.restore = function(db_name){ fs.createReadStream( __dirname + '/crontabs/' + db_name).pipe(fs.createWriteStream( __dirname + '/crontabs/crontab.db')); db.loadDatabase(); // reload the database }; exports.reload_db= function(){ db.loadDatabase(); }; exports.get_env = function(){ if (fs.existsSync(exports.env_file)) { return fs.readFileSync(exports.env_file , 'utf8').replace("\n", "\n"); } return ""; }; exports.import_crontab = function(){ exec("crontab -l", function(error, stdout, stderr){ var lines = stdout.split("\n"); var namePrefix = new Date().getTime(); lines.forEach(function(line, index){ var regex = /^((\@[a-zA-Z]+\s)|(([^\s]+)\s([^\s]+)\s([^\s]+)\s([^\s]+)\s([^\s]+)\s))/; var command = line.replace(regex, '').trim(); var schedule = line.replace(command, '').trim(); if(command && schedule){ var name = namePrefix + '_' + index; db.findOne({ command: command, schedule: schedule }, function(err, doc) { if(err) { throw err; } if(!doc){ exports.create_new(name, command, schedule, null); } else{ doc.command = command; doc.schedule = schedule; exports.update(doc); } }); } }); }); };