mirror of
https://github.com/gchq/CyberChef
synced 2025-01-23 09:45:02 +00:00
debugging File shim
This commit is contained in:
parent
14d591caa1
commit
d080c5dd14
7 changed files with 23 additions and 20 deletions
|
@ -44,10 +44,6 @@ class Dish {
|
||||||
if (dishOrInput &&
|
if (dishOrInput &&
|
||||||
dishOrInput.hasOwnProperty("value") &&
|
dishOrInput.hasOwnProperty("value") &&
|
||||||
dishOrInput.hasOwnProperty("type")) {
|
dishOrInput.hasOwnProperty("type")) {
|
||||||
console.log('first setting');
|
|
||||||
console.log(dishOrInput);
|
|
||||||
console.log(dishOrInput.constructor.name);
|
|
||||||
console.log(dishOrInput.value);
|
|
||||||
this.set(dishOrInput.value, dishOrInput.type);
|
this.set(dishOrInput.value, dishOrInput.type);
|
||||||
// input and type defined separately
|
// input and type defined separately
|
||||||
} else if (dishOrInput && type) {
|
} else if (dishOrInput && type) {
|
||||||
|
@ -103,8 +99,6 @@ class Dish {
|
||||||
* @returns {string} The data type as a string.
|
* @returns {string} The data type as a string.
|
||||||
*/
|
*/
|
||||||
static enumLookup(typeEnum) {
|
static enumLookup(typeEnum) {
|
||||||
console.trace('enumLookup');
|
|
||||||
console.log('type ' + typeEnum);
|
|
||||||
switch (typeEnum) {
|
switch (typeEnum) {
|
||||||
case Dish.BYTE_ARRAY:
|
case Dish.BYTE_ARRAY:
|
||||||
return "byteArray";
|
return "byteArray";
|
||||||
|
@ -180,16 +174,11 @@ class Dish {
|
||||||
type = Dish.typeEnum(type);
|
type = Dish.typeEnum(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Dish setting:');
|
|
||||||
console.log(value);
|
|
||||||
console.log(type);
|
|
||||||
|
|
||||||
log.debug("Dish type: " + Dish.enumLookup(type));
|
log.debug("Dish type: " + Dish.enumLookup(type));
|
||||||
this.value = value;
|
this.value = value;
|
||||||
this.type = type;
|
this.type = type;
|
||||||
|
|
||||||
if (!this.valid()) {
|
if (!this.valid()) {
|
||||||
console.log('invalid!');
|
|
||||||
const sample = Utils.truncate(JSON.stringify(this.value), 13);
|
const sample = Utils.truncate(JSON.stringify(this.value), 13);
|
||||||
throw new DishError(`Data is not a valid ${Dish.enumLookup(type)}: ${sample}`);
|
throw new DishError(`Data is not a valid ${Dish.enumLookup(type)}: ${sample}`);
|
||||||
}
|
}
|
||||||
|
@ -231,8 +220,6 @@ class Dish {
|
||||||
// All values can be serialised in some manner, so we return true in all cases
|
// All values can be serialised in some manner, so we return true in all cases
|
||||||
return true;
|
return true;
|
||||||
case Dish.FILE:
|
case Dish.FILE:
|
||||||
console.log("Validating on file");
|
|
||||||
console.log(this.value instanceof File);
|
|
||||||
return this.value instanceof File;
|
return this.value instanceof File;
|
||||||
case Dish.LIST_FILE:
|
case Dish.LIST_FILE:
|
||||||
return this.value instanceof Array &&
|
return this.value instanceof Array &&
|
||||||
|
@ -349,13 +336,13 @@ class Dish {
|
||||||
|
|
||||||
// Node environment => translate is sync
|
// Node environment => translate is sync
|
||||||
if (Utils.isNode()) {
|
if (Utils.isNode()) {
|
||||||
console.log('_translate toType:');
|
console.log('Running in node');
|
||||||
console.log(toType);
|
|
||||||
this._toByteArray();
|
this._toByteArray();
|
||||||
this._fromByteArray(toType, notUTF8);
|
this._fromByteArray(toType, notUTF8);
|
||||||
|
|
||||||
// Browser environment => translate is async
|
// Browser environment => translate is async
|
||||||
} else {
|
} else {
|
||||||
|
console.log('Running in browser');
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
this._toByteArray()
|
this._toByteArray()
|
||||||
.then(() => this.type = Dish.BYTE_ARRAY)
|
.then(() => this.type = Dish.BYTE_ARRAY)
|
||||||
|
@ -404,7 +391,6 @@ class Dish {
|
||||||
};
|
};
|
||||||
|
|
||||||
try {
|
try {
|
||||||
console.log("_tyByteArray this.type: " + this.type);
|
|
||||||
return toByteArrayFuncs[Utils.isNode() && "node" || "browser"][this.type]();
|
return toByteArrayFuncs[Utils.isNode() && "node" || "browser"][this.type]();
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
throw new DishError(`Error translating from ${Dish.enumLookup(this.type)} to byteArray: ${err}`);
|
throw new DishError(`Error translating from ${Dish.enumLookup(this.type)} to byteArray: ${err}`);
|
||||||
|
|
|
@ -967,6 +967,10 @@ class Utils {
|
||||||
throw new TypeError("Browser environment cannot support readFileSync");
|
throw new TypeError("Browser environment cannot support readFileSync");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
console.log('readFileSync:');
|
||||||
|
console.log(file);
|
||||||
|
console.log(Buffer.from(file.data).toString());
|
||||||
|
|
||||||
return Buffer.from(file.data).buffer;
|
return Buffer.from(file.data).buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,9 +19,12 @@ class DishFile extends DishTranslationType {
|
||||||
static toByteArray() {
|
static toByteArray() {
|
||||||
DishFile.checkForValue(this.value);
|
DishFile.checkForValue(this.value);
|
||||||
if (Utils.isNode()) {
|
if (Utils.isNode()) {
|
||||||
console.log("valie: ");
|
console.log('toByteArray original value:');
|
||||||
console.log(this.value);
|
console.log(this.value);
|
||||||
|
// this.value = Utils.readFileSync(this.value);
|
||||||
this.value = Array.prototype.slice.call(Utils.readFileSync(this.value));
|
this.value = Array.prototype.slice.call(Utils.readFileSync(this.value));
|
||||||
|
console.log('toByteArray value:');
|
||||||
|
console.log(this.value);
|
||||||
} else {
|
} else {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
Utils.readFile(this.value)
|
Utils.readFile(this.value)
|
||||||
|
@ -40,6 +43,8 @@ class DishFile extends DishTranslationType {
|
||||||
static fromByteArray() {
|
static fromByteArray() {
|
||||||
DishFile.checkForValue(this.value);
|
DishFile.checkForValue(this.value);
|
||||||
this.value = new File(this.value, "unknown");
|
this.value = new File(this.value, "unknown");
|
||||||
|
console.log('from Byte array');
|
||||||
|
console.log(this.value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,8 +17,10 @@ class DishString extends DishTranslationType {
|
||||||
* convert the given value to a ByteArray
|
* convert the given value to a ByteArray
|
||||||
*/
|
*/
|
||||||
static toByteArray() {
|
static toByteArray() {
|
||||||
|
console.log('string to byte array');
|
||||||
DishString.checkForValue(this.value);
|
DishString.checkForValue(this.value);
|
||||||
this.value = this.value ? Utils.strToByteArray(this.value) : [];
|
this.value = this.value ? Utils.strToByteArray(this.value) : [];
|
||||||
|
console.log(this.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -132,6 +132,8 @@ class Tar extends Operation {
|
||||||
tarball.writeBytes(input);
|
tarball.writeBytes(input);
|
||||||
tarball.writeEndBlocks();
|
tarball.writeEndBlocks();
|
||||||
|
|
||||||
|
console.log('Tar bytes');
|
||||||
|
console.log(tarball.bytes);
|
||||||
return new File([new Uint8Array(tarball.bytes)], args[0]);
|
return new File([new Uint8Array(tarball.bytes)], args[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,10 +24,16 @@ class File {
|
||||||
* @param {Object} stats (optional) - file stats e.g. lastModified
|
* @param {Object} stats (optional) - file stats e.g. lastModified
|
||||||
*/
|
*/
|
||||||
constructor(data, name="", stats={}) {
|
constructor(data, name="", stats={}) {
|
||||||
this.data = Buffer.from(data);
|
// Look at File API definition to see how to handle this.
|
||||||
|
this.data = Buffer.from(data[0]);
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.lastModified = stats.lastModified || Date.now();
|
this.lastModified = stats.lastModified || Date.now();
|
||||||
this.type = stats.type || mime.getType(this.name);
|
this.type = stats.type || mime.getType(this.name);
|
||||||
|
|
||||||
|
console.log('File constructor');
|
||||||
|
console.log(typeof data);
|
||||||
|
console.log(data);
|
||||||
|
console.log(this.data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -197,8 +197,6 @@ export function wrap(OpClass) {
|
||||||
wrapped = (input, args=null) => {
|
wrapped = (input, args=null) => {
|
||||||
const {transformedInput, transformedArgs} = prepareOp(opInstance, input, args);
|
const {transformedInput, transformedArgs} = prepareOp(opInstance, input, args);
|
||||||
const result = opInstance.run(transformedInput, transformedArgs);
|
const result = opInstance.run(transformedInput, transformedArgs);
|
||||||
console.log('Result:');
|
|
||||||
console.log(result);
|
|
||||||
return new NodeDish({
|
return new NodeDish({
|
||||||
value: result,
|
value: result,
|
||||||
type: opInstance.outputType,
|
type: opInstance.outputType,
|
||||||
|
|
Loading…
Reference in a new issue