Operations can now set options from within the worker
This commit is contained in:
parent
13f07abb8a
commit
f6b52b7c82
@ -97,6 +97,9 @@
|
|||||||
|
|
||||||
"COMPILE_TIME": false,
|
"COMPILE_TIME": false,
|
||||||
"COMPILE_MSG": false,
|
"COMPILE_MSG": false,
|
||||||
"PKG_VERSION": false
|
"PKG_VERSION": false,
|
||||||
|
"ENVIRONMENT_IS_WORKER": false,
|
||||||
|
"ENVIRONMENT_IS_NODE": false,
|
||||||
|
"ENVIRONMENT_IS_WEB": false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
21
Gruntfile.js
21
Gruntfile.js
@ -72,7 +72,16 @@ module.exports = function (grunt) {
|
|||||||
BUILD_CONSTANTS = {
|
BUILD_CONSTANTS = {
|
||||||
COMPILE_TIME: JSON.stringify(compileTime),
|
COMPILE_TIME: JSON.stringify(compileTime),
|
||||||
COMPILE_MSG: JSON.stringify(grunt.option("compile-msg") || grunt.option("msg") || ""),
|
COMPILE_MSG: JSON.stringify(grunt.option("compile-msg") || grunt.option("msg") || ""),
|
||||||
PKG_VERSION: JSON.stringify(pkg.version)
|
PKG_VERSION: JSON.stringify(pkg.version),
|
||||||
|
ENVIRONMENT_IS_WORKER: function() {
|
||||||
|
return typeof importScripts === "function";
|
||||||
|
},
|
||||||
|
ENVIRONMENT_IS_NODE: function() {
|
||||||
|
return typeof process === "object" && typeof require === "function";
|
||||||
|
},
|
||||||
|
ENVIRONMENT_IS_WEB: function() {
|
||||||
|
return typeof window === "object";
|
||||||
|
}
|
||||||
},
|
},
|
||||||
moduleEntryPoints = listEntryModules();
|
moduleEntryPoints = listEntryModules();
|
||||||
|
|
||||||
@ -277,7 +286,10 @@ module.exports = function (grunt) {
|
|||||||
output: {
|
output: {
|
||||||
filename: "index.js",
|
filename: "index.js",
|
||||||
path: __dirname + "/build/test"
|
path: __dirname + "/build/test"
|
||||||
}
|
},
|
||||||
|
plugins: [
|
||||||
|
new webpack.DefinePlugin(BUILD_CONSTANTS)
|
||||||
|
]
|
||||||
},
|
},
|
||||||
node: {
|
node: {
|
||||||
target: "node",
|
target: "node",
|
||||||
@ -288,7 +300,10 @@ module.exports = function (grunt) {
|
|||||||
path: __dirname + "/build/node",
|
path: __dirname + "/build/node",
|
||||||
library: "CyberChef",
|
library: "CyberChef",
|
||||||
libraryTarget: "commonjs2"
|
libraryTarget: "commonjs2"
|
||||||
}
|
},
|
||||||
|
plugins: [
|
||||||
|
new webpack.DefinePlugin(BUILD_CONSTANTS)
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"webpack-dev-server": {
|
"webpack-dev-server": {
|
||||||
|
@ -30,7 +30,6 @@ const Chef = function() {
|
|||||||
* @returns {string} response.result - The output of the recipe
|
* @returns {string} response.result - The output of the recipe
|
||||||
* @returns {string} response.type - The data type of the result
|
* @returns {string} response.type - The data type of the result
|
||||||
* @returns {number} response.progress - The position that we have got to in the recipe
|
* @returns {number} response.progress - The position that we have got to in the recipe
|
||||||
* @returns {number} response.options - The app options object (which may have been changed)
|
|
||||||
* @returns {number} response.duration - The number of ms it took to execute the recipe
|
* @returns {number} response.duration - The number of ms it took to execute the recipe
|
||||||
* @returns {number} response.error - The error object thrown by a failed operation (false if no error)
|
* @returns {number} response.error - The error object thrown by a failed operation (false if no error)
|
||||||
*/
|
*/
|
||||||
@ -40,12 +39,7 @@ Chef.prototype.bake = async function(inputText, recipeConfig, options, progress,
|
|||||||
containsFc = recipe.containsFlowControl(),
|
containsFc = recipe.containsFlowControl(),
|
||||||
error = false;
|
error = false;
|
||||||
|
|
||||||
// Reset attemptHighlight flag
|
if (containsFc && ENVIRONMENT_IS_WORKER()) self.setOption("attemptHighlight", false);
|
||||||
if (options.hasOwnProperty("attemptHighlight")) {
|
|
||||||
options.attemptHighlight = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (containsFc) options.attemptHighlight = false;
|
|
||||||
|
|
||||||
// Clean up progress
|
// Clean up progress
|
||||||
if (progress >= recipeConfig.length) {
|
if (progress >= recipeConfig.length) {
|
||||||
@ -86,7 +80,6 @@ Chef.prototype.bake = async function(inputText, recipeConfig, options, progress,
|
|||||||
this.dish.get(Dish.STRING),
|
this.dish.get(Dish.STRING),
|
||||||
type: Dish.enumLookup(this.dish.type),
|
type: Dish.enumLookup(this.dish.type),
|
||||||
progress: progress,
|
progress: progress,
|
||||||
options: options,
|
|
||||||
duration: new Date().getTime() - startTime,
|
duration: new Date().getTime() - startTime,
|
||||||
error: error
|
error: error
|
||||||
};
|
};
|
||||||
|
@ -41,23 +41,24 @@ self.postMessage({
|
|||||||
*/
|
*/
|
||||||
self.addEventListener("message", function(e) {
|
self.addEventListener("message", function(e) {
|
||||||
// Handle message
|
// Handle message
|
||||||
switch (e.data.action) {
|
const r = e.data;
|
||||||
|
switch (r.action) {
|
||||||
case "bake":
|
case "bake":
|
||||||
bake(e.data.data);
|
bake(r.data);
|
||||||
break;
|
break;
|
||||||
case "silentBake":
|
case "silentBake":
|
||||||
silentBake(e.data.data);
|
silentBake(r.data);
|
||||||
break;
|
break;
|
||||||
case "docURL":
|
case "docURL":
|
||||||
// Used to set the URL of the current document so that scripts can be
|
// Used to set the URL of the current document so that scripts can be
|
||||||
// imported into an inline worker.
|
// imported into an inline worker.
|
||||||
self.docURL = e.data.data;
|
self.docURL = r.data;
|
||||||
break;
|
break;
|
||||||
case "highlight":
|
case "highlight":
|
||||||
calculateHighlights(
|
calculateHighlights(
|
||||||
e.data.data.recipeConfig,
|
r.data.recipeConfig,
|
||||||
e.data.data.direction,
|
r.data.direction,
|
||||||
e.data.data.pos
|
r.data.pos
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -158,3 +159,20 @@ self.sendStatusMessage = function(msg) {
|
|||||||
data: msg
|
data: msg
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send an option value update to the app.
|
||||||
|
*
|
||||||
|
* @param {string} option
|
||||||
|
* @param {*} value
|
||||||
|
*/
|
||||||
|
self.setOption = function(option, value) {
|
||||||
|
self.postMessage({
|
||||||
|
action: "optionUpdate",
|
||||||
|
data: {
|
||||||
|
option: option,
|
||||||
|
value: value
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
@ -234,7 +234,7 @@ const Utils = {
|
|||||||
* @returns {string}
|
* @returns {string}
|
||||||
*/
|
*/
|
||||||
printable: function(str, preserveWs) {
|
printable: function(str, preserveWs) {
|
||||||
if (typeof window !== "undefined" && window.app && !window.app.options.treatAsUtf8) {
|
if (ENVIRONMENT_IS_WEB() && window.app && !window.app.options.treatAsUtf8) {
|
||||||
str = Utils.byteArrayToChars(Utils.strToByteArray(str));
|
str = Utils.byteArrayToChars(Utils.strToByteArray(str));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -384,9 +384,13 @@ const Utils = {
|
|||||||
let wordArray = CryptoJS.enc.Utf8.parse(str),
|
let wordArray = CryptoJS.enc.Utf8.parse(str),
|
||||||
byteArray = Utils.wordArrayToByteArray(wordArray);
|
byteArray = Utils.wordArrayToByteArray(wordArray);
|
||||||
|
|
||||||
if (typeof window !== "undefined" && str.length !== wordArray.sigBytes) {
|
if (str.length !== wordArray.sigBytes) {
|
||||||
|
if (ENVIRONMENT_IS_WORKER()) {
|
||||||
|
self.setOption("attemptHighlight", false);
|
||||||
|
} else if (ENVIRONMENT_IS_WEB()) {
|
||||||
window.app.options.attemptHighlight = false;
|
window.app.options.attemptHighlight = false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return byteArray;
|
return byteArray;
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -448,8 +452,13 @@ const Utils = {
|
|||||||
let wordArray = new CryptoJS.lib.WordArray.init(words, byteArray.length),
|
let wordArray = new CryptoJS.lib.WordArray.init(words, byteArray.length),
|
||||||
str = CryptoJS.enc.Utf8.stringify(wordArray);
|
str = CryptoJS.enc.Utf8.stringify(wordArray);
|
||||||
|
|
||||||
if (typeof window !== "undefined" && str.length !== wordArray.sigBytes)
|
if (str.length !== wordArray.sigBytes) {
|
||||||
|
if (ENVIRONMENT_IS_WORKER()) {
|
||||||
|
self.setOption("attemptHighlight", false);
|
||||||
|
} else if (ENVIRONMENT_IS_WEB()) {
|
||||||
window.app.options.attemptHighlight = false;
|
window.app.options.attemptHighlight = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
return str;
|
return str;
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// If it fails, treat it as ANSI
|
// If it fails, treat it as ANSI
|
||||||
|
@ -137,7 +137,8 @@ const BitwiseOp = {
|
|||||||
|
|
||||||
input = input.slice(sampleOffset, sampleOffset + sampleLength);
|
input = input.slice(sampleOffset, sampleOffset + sampleLength);
|
||||||
|
|
||||||
if (self) self.sendStatusMessage("Calculating " + Math.pow(256, keyLength) + " values...");
|
if (ENVIRONMENT_IS_WORKER())
|
||||||
|
self.sendStatusMessage("Calculating " + Math.pow(256, keyLength) + " values...");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts an integer to an array of bytes expressing that number.
|
* Converts an integer to an array of bytes expressing that number.
|
||||||
@ -156,7 +157,7 @@ const BitwiseOp = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
for (let key = 1, l = Math.pow(256, keyLength); key < l; key++) {
|
for (let key = 1, l = Math.pow(256, keyLength); key < l; key++) {
|
||||||
if (key % 10000 === 0 && self) {
|
if (key % 10000 === 0 && ENVIRONMENT_IS_WORKER()) {
|
||||||
self.sendStatusMessage("Calculating " + l + " values... " + Math.floor(key / l * 100) + "%");
|
self.sendStatusMessage("Calculating " + l + " values... " + Math.floor(key / l * 100) + "%");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,11 +119,11 @@ const ByteRepr = {
|
|||||||
else if (ordinal < 4294967296) padding = 8;
|
else if (ordinal < 4294967296) padding = 8;
|
||||||
else padding = 2;
|
else padding = 2;
|
||||||
|
|
||||||
if (padding > 2 && app) app.options.attemptHighlight = false;
|
if (padding > 2 && ENVIRONMENT_IS_WORKER()) self.setOption("attemptHighlight", false);
|
||||||
|
|
||||||
output += Utils.hex(ordinal, padding) + delim;
|
output += Utils.hex(ordinal, padding) + delim;
|
||||||
} else {
|
} else {
|
||||||
if (app) app.options.attemptHighlight = false;
|
if (ENVIRONMENT_IS_WORKER()) self.setOption("attemptHighlight", false);
|
||||||
output += ordinal.toString(base) + delim;
|
output += ordinal.toString(base) + delim;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -149,9 +149,7 @@ const ByteRepr = {
|
|||||||
throw "Error: Base argument must be between 2 and 36";
|
throw "Error: Base argument must be between 2 and 36";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (base !== 16 && app) {
|
if (base !== 16 && ENVIRONMENT_IS_WORKER()) self.setOption("attemptHighlight", false);
|
||||||
app.options.attemptHighlight = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Split into groups of 2 if the whole string is concatenated and
|
// Split into groups of 2 if the whole string is concatenated and
|
||||||
// too long to be a single character
|
// too long to be a single character
|
||||||
|
@ -92,7 +92,7 @@ const Hexdump = {
|
|||||||
const w = (width - 13) / 4;
|
const w = (width - 13) / 4;
|
||||||
// w should be the specified width of the hexdump and therefore a round number
|
// w should be the specified width of the hexdump and therefore a round number
|
||||||
if (Math.floor(w) !== w || input.indexOf("\r") !== -1 || output.indexOf(13) !== -1) {
|
if (Math.floor(w) !== w || input.indexOf("\r") !== -1 || output.indexOf(13) !== -1) {
|
||||||
//TODO if (self) self.setOption("attemptHighlight", false);
|
if (ENVIRONMENT_IS_WORKER()) self.setOption("attemptHighlight", false);
|
||||||
}
|
}
|
||||||
return output;
|
return output;
|
||||||
},
|
},
|
||||||
|
@ -105,6 +105,9 @@ App.prototype.handleError = function(err) {
|
|||||||
App.prototype.bake = function(step) {
|
App.prototype.bake = function(step) {
|
||||||
if (this.baking) return;
|
if (this.baking) return;
|
||||||
|
|
||||||
|
// Reset attemptHighlight flag
|
||||||
|
this.options.attemptHighlight = true;
|
||||||
|
|
||||||
this.manager.worker.bake(
|
this.manager.worker.bake(
|
||||||
this.getInput(), // The user's input
|
this.getInput(), // The user's input
|
||||||
this.getRecipeConfig(), // The configuration of the recipe
|
this.getRecipeConfig(), // The configuration of the recipe
|
||||||
|
@ -40,12 +40,13 @@ WorkerWaiter.prototype.registerChefWorker = function() {
|
|||||||
* @param {MessageEvent} e
|
* @param {MessageEvent} e
|
||||||
*/
|
*/
|
||||||
WorkerWaiter.prototype.handleChefMessage = function(e) {
|
WorkerWaiter.prototype.handleChefMessage = function(e) {
|
||||||
switch (e.data.action) {
|
const r = e.data;
|
||||||
|
switch (r.action) {
|
||||||
case "bakeSuccess":
|
case "bakeSuccess":
|
||||||
this.bakingComplete(e.data.data);
|
this.bakingComplete(r.data);
|
||||||
break;
|
break;
|
||||||
case "bakeError":
|
case "bakeError":
|
||||||
this.app.handleError(e.data.data);
|
this.app.handleError(r.data);
|
||||||
this.setBakingStatus(false);
|
this.setBakingStatus(false);
|
||||||
break;
|
break;
|
||||||
case "silentBakeComplete":
|
case "silentBakeComplete":
|
||||||
@ -55,10 +56,13 @@ WorkerWaiter.prototype.handleChefMessage = function(e) {
|
|||||||
this.app.loaded();
|
this.app.loaded();
|
||||||
break;
|
break;
|
||||||
case "statusMessage":
|
case "statusMessage":
|
||||||
this.manager.output.setStatusMsg(e.data.data);
|
this.manager.output.setStatusMsg(r.data);
|
||||||
|
break;
|
||||||
|
case "optionUpdate":
|
||||||
|
this.app.options[r.data.option] = r.data.value;
|
||||||
break;
|
break;
|
||||||
case "highlightsCalculated":
|
case "highlightsCalculated":
|
||||||
this.manager.highlighter.displayHighlights(e.data.data.pos, e.data.data.direction);
|
this.manager.highlighter.displayHighlights(r.data.pos, r.data.direction);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
console.error("Unrecognised message from ChefWorker", e);
|
console.error("Unrecognised message from ChefWorker", e);
|
||||||
@ -104,7 +108,6 @@ WorkerWaiter.prototype.bakingComplete = function(response) {
|
|||||||
this.app.handleError(response.error);
|
this.app.handleError(response.error);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.app.options = response.options;
|
|
||||||
this.app.dishStr = response.type === "html" ? Utils.stripHtmlTags(response.result, true) : response.result;
|
this.app.dishStr = response.type === "html" ? Utils.stripHtmlTags(response.result, true) : response.result;
|
||||||
this.app.progress = response.progress;
|
this.app.progress = response.progress;
|
||||||
this.manager.recipe.updateBreakpointIndicator(response.progress);
|
this.manager.recipe.updateBreakpointIndicator(response.progress);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user