UNPKG

iobroker.backitup

Version:

Backitup enables the cyclic creation of backups of an IoBroker / Homematic installation

122 lines (108 loc) 3.74 kB
'use strict'; const copyFile = require('../tools').copyFile; const path = require('path'); const fs = require('fs'); function copyFiles(dir, fileNames, log, errors, callback) { if (!fileNames || !fileNames.length) { callback(); } else { let fileName = fileNames.shift(); fileName = fileName.replace(/\\/g, '/'); const onlyFileName = fileName.split('/').pop(); try { log.debug('Copy ' + onlyFileName + '...'); copyFile(fileName, path.join(dir, onlyFileName), err => { if (err) { errors.cifs = err; log.error(err); } setImmediate(copyFiles, dir, fileNames, log, errors, callback); }); } catch (e) { log.error(e); errors.cifs = e; setImmediate(copyFiles, dir, fileNames, log, errors, callback); } } } function deleteFiles(files, log, errors) { try { for (let f = 0; f < files.length; f++) { log.debug('delete ' + files[f]); fs.unlinkSync(files[f]); } return true; } catch (e) { errors.cifs = errors.cifs || e; log.error(e); } } function cleanFiles(dir, names, num, log, errors) { if (!num) return; try { if (dir[dir.length - 1] !== '/') { dir += '/'; } let result = fs.readdirSync(dir); if (result && result.length) { const files = []; names.forEach(name => { const subResult = result.filter(a => a.startsWith(name)); if (subResult.length > num) { // delete oldest files subResult.sort((a, b) => { const at = fs.statSync(dir + a).ctime; const bt = fs.statSync(dir + b).ctime; if (at > bt) return -1; if (at < bt) return 1; return 0; }); for (let i = num; i < subResult.length; i++) { files.push(path.join(dir, subResult[i])); } } }); deleteFiles(files, log, errors); } } catch (e) { errors.cifs = errors.cifs || e; } } function command(options, log, callback) { if (options.dir && options.context && options.context.fileNames && options.context.fileNames.length) { const fileNames = JSON.parse(JSON.stringify(options.context.fileNames)); let dir = options.dir.replace(/\\/g, '/'); if (dir[0] !== '/' && !dir.match(/\w:/)) { dir = '/' + (dir || ''); } if (fs.existsSync(options.dir)) { copyFiles(options.dir, fileNames, log, options.context.errors, err => { if (err) { log.error(err); options.context.errors.cifs = options.context.errors.cifs || err; } if (options.deleteOldBackup === true) { if (cleanFiles(dir, options.context.types, options.deleteBackupAfter, log, options.context.errors)) { !options.context.errors.cifs && options.context.done.push('cifs'); } } else { !options.context.errors.cifs && options.context.done.push('cifs'); } if (callback) { callback(err); callback = null; } }); } else if (options.mountType === 'Copy') { callback(`Path "${options.dir}" not found`); } else { callback(); } } else { callback(); } } module.exports = { command, ignoreErrors: true };