Put zip feature back until debug until new agent.

This commit is contained in:
Ylian Saint-Hilaire 2020-08-19 14:01:05 -07:00
parent 6b3a75da09
commit 972e254d91
3 changed files with 1121 additions and 1123 deletions

View File

@ -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

View File

@ -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;
} }