mirror of
https://github.com/gchq/CyberChef.git
synced 2024-11-16 00:48:31 +01:00
80 lines
2 KiB
JavaScript
80 lines
2 KiB
JavaScript
/**
|
|
* @author n1474335 [n1474335@gmail.com]
|
|
* @copyright Crown Copyright 2018
|
|
* @license Apache-2.0
|
|
*/
|
|
|
|
import Operation from "../Operation";
|
|
import OperationError from "../errors/OperationError";
|
|
import Utils from "../Utils";
|
|
|
|
/**
|
|
* CSV to JSON operation
|
|
*/
|
|
class CSVToJSON extends Operation {
|
|
|
|
/**
|
|
* CSVToJSON constructor
|
|
*/
|
|
constructor() {
|
|
super();
|
|
|
|
this.name = "CSV to JSON";
|
|
this.module = "Default";
|
|
this.description = "Converts a CSV file to JSON format.";
|
|
this.infoURL = "https://wikipedia.org/wiki/Comma-separated_values";
|
|
this.inputType = "string";
|
|
this.outputType = "JSON";
|
|
this.args = [
|
|
{
|
|
name: "Cell delimiters",
|
|
type: "binaryShortString",
|
|
value: ","
|
|
},
|
|
{
|
|
name: "Row delimiters",
|
|
type: "binaryShortString",
|
|
value: "\\r\\n"
|
|
},
|
|
{
|
|
name: "Format",
|
|
type: "option",
|
|
value: ["Array of dictionaries", "Array of arrays"]
|
|
}
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @param {string} input
|
|
* @param {Object[]} args
|
|
* @returns {JSON}
|
|
*/
|
|
run(input, args) {
|
|
const [cellDelims, rowDelims, format] = args;
|
|
let json, header;
|
|
|
|
try {
|
|
json = Utils.parseCSV(input, cellDelims.split(""), rowDelims.split(""));
|
|
} catch (err) {
|
|
throw new OperationError("Unable to parse CSV: " + err);
|
|
}
|
|
|
|
switch (format) {
|
|
case "Array of dictionaries":
|
|
header = json[0];
|
|
return json.slice(1).map(row => {
|
|
const obj = {};
|
|
header.forEach((h, i) => {
|
|
obj[h] = row[i];
|
|
});
|
|
return obj;
|
|
});
|
|
case "Array of arrays":
|
|
default:
|
|
return json;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
export default CSVToJSON;
|