mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 23:13:21 -05:00
Put zip feature back until debug until new agent.
This commit is contained in:
parent
6b3a75da09
commit
972e254d91
@ -2140,34 +2140,28 @@ function createMeshCore(agent) {
|
|||||||
}
|
}
|
||||||
case 'zip':
|
case 'zip':
|
||||||
// Zip a bunch of files
|
// Zip a bunch of files
|
||||||
|
if (this.zip != null) return; // Zip operating is currently running, exit now.
|
||||||
|
|
||||||
|
// Check that the specified files exist & build full paths
|
||||||
var fp, stat, p = [];
|
var fp, stat, p = [];
|
||||||
for (var i in cmd.files) {
|
for (var i in cmd.files) { fp = cmd.path + '/' + cmd.files[i]; stat = null; try { stat = fs.statSync(fp); } catch (e) { } if (stat != null) { p.push(fp); } }
|
||||||
// Right now, we only zip files.
|
if (p.length == 0) return; // No files, quit now.
|
||||||
// TODO: Support folder compression
|
|
||||||
// TODO: Support compression relative to a root path
|
// Setup file compression
|
||||||
// TODO: Support the 'cancel' operation below
|
|
||||||
fp = cmd.path + '/' + cmd.files[i];
|
|
||||||
stat = null;
|
|
||||||
try { stat = fs.statSync(fp); } catch (e) { }
|
|
||||||
if ((stat != null) && (stat.isDirectory() == false) && (stat.size != null) && (stat.size > 0)) { p.push(fp); }
|
|
||||||
}
|
|
||||||
if (p.length == 0) return;
|
|
||||||
var ofile = cmd.path + '/' + cmd.output;
|
var ofile = cmd.path + '/' + cmd.output;
|
||||||
this.write(Buffer.from(JSON.stringify({ action: 'dialogmessage', msg: 'zipping' })));
|
this.write(Buffer.from(JSON.stringify({ action: 'dialogmessage', msg: 'zipping' })));
|
||||||
var out = require('fs').createWriteStream(ofile, { flags: 'wb' });
|
var out = require('fs').createWriteStream(ofile, { flags: 'wb' });
|
||||||
out.fname = ofile;
|
|
||||||
out.xws = this;
|
out.xws = this;
|
||||||
out.on('close', function () {
|
out.on('close', function () { this.xws.write(Buffer.from(JSON.stringify({ action: 'dialogmessage', msg: null }))); this.xws.write(Buffer.from(JSON.stringify({ action: 'refresh' }))); this.xws.zip = null; });
|
||||||
this.xws.write(Buffer.from(JSON.stringify({ action: 'dialogmessage', msg: null })));
|
this.zip = require('zip-writer').write({ files: p, basePath: cmd.path });
|
||||||
this.xws.write(Buffer.from(JSON.stringify({ action: 'refresh' })));
|
this.zip.xws = this;
|
||||||
});
|
this.zip.on('progress', require('events').moderated(function (name, p) { this.xws.write(Buffer.from(JSON.stringify({ action: 'dialogmessage', msg: 'zippingFile', file: ((process.platform == 'win32') ? (name.split('/').join('\\')) : name), progress: p }))); }, 2000));
|
||||||
this.zip = require('zip-writer').write({ files: p });
|
|
||||||
this.zip.pipe(out);
|
this.zip.pipe(out);
|
||||||
break;
|
break;
|
||||||
case 'cancel':
|
case 'cancel':
|
||||||
// TODO: Cancel zip operation if present
|
// Cancel zip operation if present
|
||||||
//sendConsoleText('Cancel operation');
|
try { this.zip.cancel(function () { }); } catch (ex) { }
|
||||||
try { this.zip.cancel(function () { sendConsoleText('Zip operation was cancelled'); }); } catch (ex) { }
|
this.zip = null;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// Unknown action, ignore it.
|
// Unknown action, ignore it.
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -7730,6 +7730,9 @@
|
|||||||
} else if ((data.msg == 'zipping') && ((!xxdialogMode) || (xxdialogTag == 'fileMsgDialog'))) {
|
} else if ((data.msg == 'zipping') && ((!xxdialogMode) || (xxdialogTag == 'fileMsgDialog'))) {
|
||||||
// Show the dialog box message
|
// Show the dialog box message
|
||||||
setDialogMode(2, "File Operation", 10, p13fileOperationDialogEx, '<div style=margin:10px>' + "Compressing files..." + '<div>', 'fileMsgDialog');
|
setDialogMode(2, "File Operation", 10, p13fileOperationDialogEx, '<div style=margin:10px>' + "Compressing files..." + '<div>', 'fileMsgDialog');
|
||||||
|
} else if ((data.msg == 'zippingFile') && ((!xxdialogMode) || (xxdialogTag == 'fileMsgDialog'))) {
|
||||||
|
// Show the dialog box message
|
||||||
|
setDialogMode(2, "File Operation", 10, p13fileOperationDialogEx, '<div style=margin:10px>' + EscapeHtml(data.file) + '<div><br /><progress value=' + EscapeHtml(data.progress) + ' style=width:100% max=100 />', 'fileMsgDialog');
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user