Merge conflicts

This commit is contained in:
n1474335 2016-12-06 18:32:39 +00:00
commit 2db810289d
3 changed files with 55 additions and 4 deletions

View File

@ -77,6 +77,7 @@ var Categories = [
"RC4",
"RC4 Drop",
"ROT13",
"ROT47",
"XOR",
"XOR Brute Force",
"Derive PBKDF2 key",

View File

@ -1390,6 +1390,21 @@ var OperationConfig = {
},
]
},
"ROT47": {
description: "A slightly more complex variation of a caesar cipher, which includes ASCII characters too. (default 47)",
run: Rotate.run_rot47,
highlight: true,
highlight_reverse: true,
input_type: "byte_array",
output_type: "byte_array",
args: [
{
name: "Amount",
type: "number",
value: Rotate.ROT47_AMOUNT
},
]
},
"Strip HTTP headers": {
description: "Removes HTTP headers from a request or response by looking for the first instance of a double newline.",
run: HTTP.run_strip_headers,

View File

@ -1,7 +1,7 @@
/**
* Bit rotation operations.
*
* @author n1474335 [n1474335@gmail.com]
* @author n1474335 [n1474335@gmail.com] & Matt C [matt@artemisbot.pw]
* @copyright Crown Copyright 2016
* @license Apache-2.0
*
@ -91,7 +91,7 @@ var Rotate = {
* @default
*/
ROT13_UPPERCASE: true,
/**
* ROT13 operation.
*
@ -124,8 +124,43 @@ var Rotate = {
}
return output;
},
/**
* @constant
* @default
*/
ROT47_AMOUNT: 47,
/**
* ROT47 operation.
*
* @param {byte_array} input
* @param {Object[]} args
* @returns {byte_array}
*/
run_rot47: function(input, args) {
var amount = args[0],
output = input,
chr;
if (amount) {
if (amount < 0) {
amount = 94 - (Math.abs(amount) % 94);
}
for (var i = 0; i < input.length; i++) {
chr = input[i];
if (chr >= 33 && chr <= 126) {
chr = (chr - 33 + amount) % 94;
output[i] = chr + 33;
}
}
}
return output;
},
/**
* Rotate right bitwise op.
*