mirror of
https://github.com/gchq/CyberChef.git
synced 2025-04-20 14:56:19 -04:00
Merge 20b2f56039
into 7c8be12d52
This commit is contained in:
commit
d05403ea40
6 changed files with 217 additions and 2 deletions
|
@ -312,6 +312,7 @@
|
||||||
"Expand alphabet range",
|
"Expand alphabet range",
|
||||||
"Drop bytes",
|
"Drop bytes",
|
||||||
"Take bytes",
|
"Take bytes",
|
||||||
|
"Insert bytes",
|
||||||
"Pad lines",
|
"Pad lines",
|
||||||
"Find / Replace",
|
"Find / Replace",
|
||||||
"Regular expression",
|
"Regular expression",
|
||||||
|
|
|
@ -29,12 +29,12 @@ class ChangeIPFormat extends Operation {
|
||||||
{
|
{
|
||||||
"name": "Input format",
|
"name": "Input format",
|
||||||
"type": "option",
|
"type": "option",
|
||||||
"value": ["Dotted Decimal", "Decimal", "Octal", "Hex"]
|
"value": ["Dotted Decimal", "Decimal", "Decimal (Little Endian)", "Octal", "Octal (Little Endian)", "Hex"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Output format",
|
"name": "Output format",
|
||||||
"type": "option",
|
"type": "option",
|
||||||
"value": ["Dotted Decimal", "Decimal", "Octal", "Hex"]
|
"value": ["Dotted Decimal", "Decimal", "Decimal (Little Endian)", "Octal", "Octal (Little Endian)", "Hex"]
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -71,9 +71,15 @@ class ChangeIPFormat extends Operation {
|
||||||
case "Decimal":
|
case "Decimal":
|
||||||
baIp = this.fromNumber(lines[i].toString(), 10);
|
baIp = this.fromNumber(lines[i].toString(), 10);
|
||||||
break;
|
break;
|
||||||
|
case "Decimal (Little Endian)":
|
||||||
|
baIp = Utils.intToByteArray(parseInt(lines[i].toString(), 10), 4, "little");
|
||||||
|
break;
|
||||||
case "Octal":
|
case "Octal":
|
||||||
baIp = this.fromNumber(lines[i].toString(), 8);
|
baIp = this.fromNumber(lines[i].toString(), 8);
|
||||||
break;
|
break;
|
||||||
|
case "Octal (Little Endian)":
|
||||||
|
baIp = Utils.intToByteArray(parseInt(lines[i].toString(), 8), 4, "little");
|
||||||
|
break;
|
||||||
case "Hex":
|
case "Hex":
|
||||||
baIp = fromHex(lines[i]);
|
baIp = fromHex(lines[i]);
|
||||||
break;
|
break;
|
||||||
|
@ -98,10 +104,18 @@ class ChangeIPFormat extends Operation {
|
||||||
decIp = ((baIp[0] << 24) | (baIp[1] << 16) | (baIp[2] << 8) | baIp[3]) >>> 0;
|
decIp = ((baIp[0] << 24) | (baIp[1] << 16) | (baIp[2] << 8) | baIp[3]) >>> 0;
|
||||||
output += decIp.toString() + "\n";
|
output += decIp.toString() + "\n";
|
||||||
break;
|
break;
|
||||||
|
case "Decimal (Little Endian)":
|
||||||
|
decIp = Utils.byteArrayToInt(baIp, "little");
|
||||||
|
output += decIp.toString() + "\n";
|
||||||
|
break;
|
||||||
case "Octal":
|
case "Octal":
|
||||||
decIp = ((baIp[0] << 24) | (baIp[1] << 16) | (baIp[2] << 8) | baIp[3]) >>> 0;
|
decIp = ((baIp[0] << 24) | (baIp[1] << 16) | (baIp[2] << 8) | baIp[3]) >>> 0;
|
||||||
output += "0" + decIp.toString(8) + "\n";
|
output += "0" + decIp.toString(8) + "\n";
|
||||||
break;
|
break;
|
||||||
|
case "Octal (Little Endian)":
|
||||||
|
decIp = Utils.byteArrayToInt(baIp, "little");
|
||||||
|
output += "0" + decIp.toString(8) + "\n";
|
||||||
|
break;
|
||||||
case "Hex":
|
case "Hex":
|
||||||
hexIp = "";
|
hexIp = "";
|
||||||
for (j = 0; j < baIp.length; j++) {
|
for (j = 0; j < baIp.length; j++) {
|
||||||
|
|
81
src/core/operations/InsertBytes.mjs
Normal file
81
src/core/operations/InsertBytes.mjs
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
/**
|
||||||
|
* @author Didier Stevens [didier.stevens@gmail.com]
|
||||||
|
* @copyright Crown Copyright 2022
|
||||||
|
* @license Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
import Operation from "../Operation.mjs";
|
||||||
|
import OperationError from "../errors/OperationError.mjs";
|
||||||
|
import {BITWISE_OP_DELIMS} from "../lib/BitwiseOp.mjs";
|
||||||
|
import Utils from "../Utils.mjs";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Insert bytes operation
|
||||||
|
*/
|
||||||
|
class InsertBytes extends Operation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* InsertBytes constructor
|
||||||
|
*/
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
|
||||||
|
this.name = "Insert bytes";
|
||||||
|
this.module = "Default";
|
||||||
|
this.description = "Insert bytes at arbitrary position. Options 'from end' and 'overwrite' available.";
|
||||||
|
this.infoURL = "";
|
||||||
|
this.inputType = "byteArray";
|
||||||
|
this.outputType = "byteArray";
|
||||||
|
this.args = [
|
||||||
|
{
|
||||||
|
"name": "Bytes",
|
||||||
|
"type": "toggleString",
|
||||||
|
"value": "",
|
||||||
|
"toggleValues": BITWISE_OP_DELIMS
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Start",
|
||||||
|
"type": "number",
|
||||||
|
"value": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "From end",
|
||||||
|
"type": "boolean",
|
||||||
|
"value": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Overwrite",
|
||||||
|
"type": "boolean",
|
||||||
|
"value": false
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {byteArray} input
|
||||||
|
* @param {Object[]} args
|
||||||
|
* @returns {byteArray}
|
||||||
|
*/
|
||||||
|
run(input, args) {
|
||||||
|
const value = Utils.convertToByteArray(args[0].string || "", args[0].option);
|
||||||
|
let start = args[1];
|
||||||
|
const fromend = args[2];
|
||||||
|
const overwrite = args[3];
|
||||||
|
|
||||||
|
if (start < 0)
|
||||||
|
throw new OperationError("Start must not be negative");
|
||||||
|
if (start > input.length)
|
||||||
|
throw new OperationError("Start must not be bigger than input");
|
||||||
|
if (fromend)
|
||||||
|
start = input.length - start;
|
||||||
|
const left = input.slice(0, start);
|
||||||
|
let right = input.slice(start);
|
||||||
|
if (overwrite)
|
||||||
|
right = right.slice(value.length);
|
||||||
|
|
||||||
|
return left.concat(value, right);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export default InsertBytes;
|
|
@ -85,6 +85,7 @@ import "./tests/Hex.mjs";
|
||||||
import "./tests/Hexdump.mjs";
|
import "./tests/Hexdump.mjs";
|
||||||
import "./tests/HKDF.mjs";
|
import "./tests/HKDF.mjs";
|
||||||
import "./tests/Image.mjs";
|
import "./tests/Image.mjs";
|
||||||
|
import "./tests/InsertBytes.mjs";
|
||||||
import "./tests/IndexOfCoincidence.mjs";
|
import "./tests/IndexOfCoincidence.mjs";
|
||||||
import "./tests/JA3Fingerprint.mjs";
|
import "./tests/JA3Fingerprint.mjs";
|
||||||
import "./tests/JA4.mjs";
|
import "./tests/JA4.mjs";
|
||||||
|
|
|
@ -48,5 +48,45 @@ TestRegister.addTests([
|
||||||
args: ["Octal", "Decimal"],
|
args: ["Octal", "Decimal"],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
}, {
|
||||||
|
name: "Change IP format: Decimal (Little Endian) to Dotted Decimal",
|
||||||
|
input: "16885952",
|
||||||
|
expectedOutput: "192.168.1.1",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Change IP format",
|
||||||
|
args: ["Decimal (Little Endian)", "Dotted Decimal"],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}, {
|
||||||
|
name: "Change IP format: Dotted Decimal to Decimal (Little Endian)",
|
||||||
|
input: "192.168.1.1",
|
||||||
|
expectedOutput: "16885952",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Change IP format",
|
||||||
|
args: ["Dotted Decimal", "Decimal (Little Endian)"],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}, {
|
||||||
|
name: "Change IP format: Octal (Little Endian) to Dotted Decimal",
|
||||||
|
input: "0100324300",
|
||||||
|
expectedOutput: "192.168.1.1",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Change IP format",
|
||||||
|
args: ["Octal (Little Endian)", "Dotted Decimal"],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}, {
|
||||||
|
name: "Change IP format: Dotted Decimal to Octal (Little Endian)",
|
||||||
|
input: "192.168.1.1",
|
||||||
|
expectedOutput: "0100324300",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Change IP format",
|
||||||
|
args: ["Dotted Decimal", "Octal (Little Endian)"],
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
|
|
78
tests/operations/tests/InsertBytes.mjs
Normal file
78
tests/operations/tests/InsertBytes.mjs
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
/**
|
||||||
|
* InsertBytes test.
|
||||||
|
*
|
||||||
|
* @author Didier Stevens [didier.stevens@gmail.com]
|
||||||
|
* @copyright Crown Copyright 2022
|
||||||
|
* @license Apache-2.0
|
||||||
|
*/
|
||||||
|
import TestRegister from "../../lib/TestRegister.mjs";
|
||||||
|
|
||||||
|
TestRegister.addTests([
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 1",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "This is a test",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "", "option": "Hex"}, 0, false, false],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 2",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "AThis is a test",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "41", "option": "Hex"}, 0, false, false],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 3",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "This is a testA",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "41", "option": "Hex"}, 0, true, false],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 4",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "Ahis is a test",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "41", "option": "Hex"}, 0, false, true],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 5",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "This is a tesA",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "41", "option": "Hex"}, 1, true, true],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Insert bytes - test 6",
|
||||||
|
input: "This is a test",
|
||||||
|
expectedOutput: "This is not a test",
|
||||||
|
recipeConfig: [
|
||||||
|
{
|
||||||
|
op: "Insert bytes",
|
||||||
|
args: [{"string": "not ", "option": "Latin1"}, 8, false, false],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
]);
|
Loading…
Add table
Add a link
Reference in a new issue