From 7d16265c4e649ca657fa3ea32b7aad092fb18513 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 19:09:57 +0000 Subject: [PATCH 1/9] =?UTF-8?q?Initial=20Commit=20=E2=80=93=20Working=20ha?= =?UTF-8?q?sh=20functionality?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package-lock.json | 5 ++++ package.json | 1 + src/core/operations/BLAKE2b.mjs | 48 ++++++++++++++++++++++++++++++ src/core/operations/BLAKE2s.mjs | 48 ++++++++++++++++++++++++++++++ tests/operations/index.mjs | 2 ++ tests/operations/tests/BLAKE2b.mjs | 47 +++++++++++++++++++++++++++++ tests/operations/tests/BLAKE2s.mjs | 38 +++++++++++++++++++++++ 7 files changed, 189 insertions(+) create mode 100644 src/core/operations/BLAKE2b.mjs create mode 100644 src/core/operations/BLAKE2s.mjs create mode 100644 tests/operations/tests/BLAKE2b.mjs create mode 100755 tests/operations/tests/BLAKE2s.mjs diff --git a/package-lock.json b/package-lock.json index 985391a9..87615219 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2249,6 +2249,11 @@ "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", "dev": true }, + "blakejs": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/blakejs/-/blakejs-1.1.0.tgz", + "integrity": "sha1-ad+S75U6qIylGjLfarHFShVfx6U=" + }, "block-stream": { "version": "0.0.9", "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", diff --git a/package.json b/package.json index 2bd5b269..320908b8 100644 --- a/package.json +++ b/package.json @@ -85,6 +85,7 @@ "babel-plugin-transform-builtin-extend": "1.1.2", "bcryptjs": "^2.4.3", "bignumber.js": "^8.1.1", + "blakejs": "^1.1.0", "bootstrap": "4.2.1", "bootstrap-colorpicker": "^2.5.3", "bootstrap-material-design": "^4.1.1", diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs new file mode 100644 index 00000000..e5bda30e --- /dev/null +++ b/src/core/operations/BLAKE2b.mjs @@ -0,0 +1,48 @@ +/** + * @author h [h] + * @copyright Crown Copyright 2019 + * @license Apache-2.0 + */ + +import Operation from "../Operation"; +import blakejs from "blakejs"; + +/** + * BLAKE2b operation + */ +class BLAKE2b extends Operation { + + /** + * BLAKE2b constructor + */ + constructor() { + super(); + + this.name = "BLAKE2b"; + this.module = "Hashing"; + this.description = "Performs BLAKE2b hashing on the input. Returns the output HEX encoded."; + this.infoURL = "https://en.wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; + this.inputType = "string"; + this.outputType = "string"; + this.args = [ + { + "name": "Size", + "type": "option", + "value": ["512", "384", "256", "160", "128"] + } + ]; + } + + /** + * @param {string} input + * @param {Object[]} args + * @returns {string} The input having been hashed with BLAKE2b, HEX encoded. + */ + run(input, args) { + const [outSize] = args; + return blakejs.blake2bHex(input, null, outSize / 8); + } + +} + +export default BLAKE2b; diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs new file mode 100644 index 00000000..b5b8ed55 --- /dev/null +++ b/src/core/operations/BLAKE2s.mjs @@ -0,0 +1,48 @@ +/** + * @author h [h] + * @copyright Crown Copyright 2019 + * @license Apache-2.0 + */ + +import Operation from "../Operation"; +import blakejs from "blakejs"; + +/** + * BLAKE2s Operation + */ +class BLAKE2s extends Operation { + + /** + * BLAKE2s constructor + */ + constructor() { + super(); + + this.name = "BLAKE2s"; + this.module = "Hashing"; + this.description = "Performs BLAKE2s hashing on the input. Returns the output HEX encoded."; + this.infoURL = "https://en.wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; + this.inputType = "string"; + this.outputType = "string"; + this.args = [ + { + "name": "Size", + "type": "option", + "value": ["256", "160", "128"] + } + ]; + } + + /** + * @param {string} input + * @param {Object[]} args + * @returns {string} The input having been hashed with BLAKE2s, HEX encoded. + */ + run(input, args) { + const [outSize] = args; + return blakejs.blake2sHex(input, null, outSize / 8); + } + +} + +export default BLAKE2s; diff --git a/tests/operations/index.mjs b/tests/operations/index.mjs index c54f15e8..07716fe2 100644 --- a/tests/operations/index.mjs +++ b/tests/operations/index.mjs @@ -86,6 +86,8 @@ import "./tests/Enigma"; import "./tests/Bombe"; import "./tests/MultipleBombe"; import "./tests/Typex"; +import "./tests/BLAKE2b"; +import "./tests/BLAKE2s"; // Cannot test operations that use the File type yet //import "./tests/SplitColourChannels"; diff --git a/tests/operations/tests/BLAKE2b.mjs b/tests/operations/tests/BLAKE2b.mjs new file mode 100644 index 00000000..9a4c211e --- /dev/null +++ b/tests/operations/tests/BLAKE2b.mjs @@ -0,0 +1,47 @@ +/** + * BitwiseOp tests + * + * @author n1474335 [n1474335@gmail.com] + * @copyright Crown Copyright 2017 + * @license Apache-2.0 + */ +import TestRegister from "../TestRegister"; + +TestRegister.addTests([ + { + name: "BLAKE2b: 512 - Hello World", + input: "Hello World", + expectedOutput: "4386a08a265111c9896f56456e2cb61a64239115c4784cf438e36cc851221972da3fb0115f73cd02486254001f878ab1fd126aac69844ef1c1ca152379d0a9bd", + recipeConfig: [ + { "op": "BLAKE2b", + "args": ["512"] } + ] + }, + { + name: "BLAKE2b: 384 - Hello World", + input: "Hello World", + expectedOutput: "4d388e82ca8f866e606b6f6f0be910abd62ad6e98c0adfc27cf35acf948986d5c5b9c18b6f47261e1e679eb98edf8e2d", + recipeConfig: [ + { "op": "BLAKE2b", + "args": ["384"] } + ] + }, + { + name: "BLAKE2b: 256 - Hello World", + input: "Hello World", + expectedOutput: "1dc01772ee0171f5f614c673e3c7fa1107a8cf727bdf5a6dadb379e93c0d1d00", + recipeConfig: [ + { "op": "BLAKE2b", + "args": ["256"] } + ] + }, + { + name: "BLAKE2b: 160 - Hello World", + input: "Hello World", + expectedOutput: "6a8489e6fd6e51fae12ab271ec7fc8134dd5d737", + recipeConfig: [ + { "op": "BLAKE2b", + "args": ["160"] } + ] + } +]); diff --git a/tests/operations/tests/BLAKE2s.mjs b/tests/operations/tests/BLAKE2s.mjs new file mode 100755 index 00000000..e08996ad --- /dev/null +++ b/tests/operations/tests/BLAKE2s.mjs @@ -0,0 +1,38 @@ +/** + * BitwiseOp tests + * + * @author n1474335 [n1474335@gmail.com] + * @copyright Crown Copyright 2017 + * @license Apache-2.0 + */ +import TestRegister from "../TestRegister"; + +TestRegister.addTests([ + { + name: "BLAKE2s: 256 - Hello World", + input: "Hello World", + expectedOutput: "7706af019148849e516f95ba630307a2018bb7bf03803eca5ed7ed2c3c013513", + recipeConfig: [ + { "op": "BLAKE2s", + "args": ["256"] } + ] + }, + { + name: "BLAKE2s: 160 - Hello World", + input: "Hello World", + expectedOutput: "0e4fcfc2ee0097ac1d72d70b595a39e09a3c7c7e", + recipeConfig: [ + { "op": "BLAKE2s", + "args": ["160"] } + ] + }, + { + name: "BLAKE2s: 128 - Hello World", + input: "Hello World", + expectedOutput: "9964ee6f36126626bf864363edfa96f6", + recipeConfig: [ + { "op": "BLAKE2s", + "args": ["128"] } + ] + } +]); From c813d17595d583e92f1a36cb2d6775863ff63510 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 19:13:00 +0000 Subject: [PATCH 2/9] Fixed Author Tags --- src/core/operations/BLAKE2b.mjs | 2 +- src/core/operations/BLAKE2s.mjs | 2 +- tests/operations/tests/BLAKE2b.mjs | 2 +- tests/operations/tests/BLAKE2s.mjs | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index e5bda30e..a7cd9b51 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -1,5 +1,5 @@ /** - * @author h [h] + * @author h345983745 * @copyright Crown Copyright 2019 * @license Apache-2.0 */ diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index b5b8ed55..a8237397 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -1,5 +1,5 @@ /** - * @author h [h] + * @author h345983745 * @copyright Crown Copyright 2019 * @license Apache-2.0 */ diff --git a/tests/operations/tests/BLAKE2b.mjs b/tests/operations/tests/BLAKE2b.mjs index 9a4c211e..41d47f23 100644 --- a/tests/operations/tests/BLAKE2b.mjs +++ b/tests/operations/tests/BLAKE2b.mjs @@ -1,7 +1,7 @@ /** * BitwiseOp tests * - * @author n1474335 [n1474335@gmail.com] + * @author h345983745 * @copyright Crown Copyright 2017 * @license Apache-2.0 */ diff --git a/tests/operations/tests/BLAKE2s.mjs b/tests/operations/tests/BLAKE2s.mjs index e08996ad..092ac29c 100755 --- a/tests/operations/tests/BLAKE2s.mjs +++ b/tests/operations/tests/BLAKE2s.mjs @@ -1,7 +1,7 @@ /** * BitwiseOp tests * - * @author n1474335 [n1474335@gmail.com] + * @author h345983745 * @copyright Crown Copyright 2017 * @license Apache-2.0 */ From 2d7e3f180ece97fff7e4679578d54851945d4620 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 19:47:51 +0000 Subject: [PATCH 3/9] Added to "Generate All Hashes" operation --- src/core/operations/GenerateAllHashes.mjs | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/core/operations/GenerateAllHashes.mjs b/src/core/operations/GenerateAllHashes.mjs index 633337f0..1fb09b5a 100644 --- a/src/core/operations/GenerateAllHashes.mjs +++ b/src/core/operations/GenerateAllHashes.mjs @@ -28,6 +28,8 @@ import Fletcher64Checksum from "./Fletcher64Checksum"; import Adler32Checksum from "./Adler32Checksum"; import CRC16Checksum from "./CRC16Checksum"; import CRC32Checksum from "./CRC32Checksum"; +import BLAKE2b from "./BLAKE2b"; +import BLAKE2s from "./BLAKE2s"; /** * Generate all hashes operation @@ -88,6 +90,14 @@ class GenerateAllHashes extends Operation { "\nWhirlpool: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool"]) + "\nSSDEEP: " + (new SSDEEP()).run(str) + "\nCTPH: " + (new CTPH()).run(str) + + "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512"]) + + "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384"]) + + "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256"]) + + "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160"]) + + "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128"]) + + "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256"]) + + "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160"]) + + "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128"]) + "\n\nChecksums:" + "\nFletcher-8: " + (new Fletcher8Checksum).run(byteArray, []) + "\nFletcher-16: " + (new Fletcher16Checksum).run(byteArray, []) + From 908043fb7f774518e9b9d8e57766417fb9367931 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 20:32:42 +0000 Subject: [PATCH 4/9] Added to Categories and updated info URL's --- src/core/config/Categories.json | 4 +++- src/core/operations/BLAKE2b.mjs | 2 +- src/core/operations/BLAKE2s.mjs | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/core/config/Categories.json b/src/core/config/Categories.json index 2fe8e8f7..ea7ca18d 100755 --- a/src/core/config/Categories.json +++ b/src/core/config/Categories.json @@ -313,7 +313,9 @@ "Adler-32 Checksum", "CRC-16 Checksum", "CRC-32 Checksum", - "TCP/IP Checksum" + "TCP/IP Checksum", + "BLAKE2b", + "BLAKE2s" ] }, { diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index a7cd9b51..5be45e70 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -21,7 +21,7 @@ class BLAKE2b extends Operation { this.name = "BLAKE2b"; this.module = "Hashing"; this.description = "Performs BLAKE2b hashing on the input. Returns the output HEX encoded."; - this.infoURL = "https://en.wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; + this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2b_algorithm"; this.inputType = "string"; this.outputType = "string"; this.args = [ diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index a8237397..bb9402f6 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -21,7 +21,7 @@ class BLAKE2s extends Operation { this.name = "BLAKE2s"; this.module = "Hashing"; this.description = "Performs BLAKE2s hashing on the input. Returns the output HEX encoded."; - this.infoURL = "https://en.wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; + this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; this.inputType = "string"; this.outputType = "string"; this.args = [ From b116b8ba1edce51162591087ac0678d180f95de9 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 21:12:03 +0000 Subject: [PATCH 5/9] Added Output Encoding Option --- src/core/operations/BLAKE2b.mjs | 23 ++++++++++++++++++++--- src/core/operations/BLAKE2s.mjs | 23 +++++++++++++++++++---- tests/operations/tests/BLAKE2b.mjs | 10 +++++----- tests/operations/tests/BLAKE2s.mjs | 8 ++++---- 4 files changed, 48 insertions(+), 16 deletions(-) diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index 5be45e70..7124cd52 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -6,6 +6,9 @@ import Operation from "../Operation"; import blakejs from "blakejs"; +import OperationError from "../errors/OperationError"; +import Utils from "../Utils"; +import { toBase64 } from "../lib/Base64"; /** * BLAKE2b operation @@ -29,6 +32,10 @@ class BLAKE2b extends Operation { "name": "Size", "type": "option", "value": ["512", "384", "256", "160", "128"] + }, { + "name": "Output Encoding", + "type": "option", + "value": ["Hex", "Base64", "Raw"] } ]; } @@ -36,11 +43,21 @@ class BLAKE2b extends Operation { /** * @param {string} input * @param {Object[]} args - * @returns {string} The input having been hashed with BLAKE2b, HEX encoded. + * @returns {string} The input having been hashed with BLAKE2b in the encoding format speicifed. */ run(input, args) { - const [outSize] = args; - return blakejs.blake2bHex(input, null, outSize / 8); + const [outSize, outFormat] = args; + + switch (outFormat) { + case "Hex": + return blakejs.blake2bHex(input, null, outSize / 8); + case "Base64": + return toBase64(blakejs.blake2b(input, null, outSize / 8)); + case "Raw": + return Utils.arrayBufferToStr(blakejs.blake2b(input, null, outSize / 8).buffer); + default: + return new OperationError("Unsupported Output Type"); + } } } diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index bb9402f6..2e7f5dd9 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -6,7 +6,9 @@ import Operation from "../Operation"; import blakejs from "blakejs"; - +import OperationError from "../errors/OperationError"; +import Utils from "../Utils"; +import { toBase64 } from "../lib/Base64"; /** * BLAKE2s Operation */ @@ -29,6 +31,10 @@ class BLAKE2s extends Operation { "name": "Size", "type": "option", "value": ["256", "160", "128"] + }, { + "name": "Output Encoding", + "type": "option", + "value": ["Hex", "Base64", "Raw"] } ]; } @@ -36,11 +42,20 @@ class BLAKE2s extends Operation { /** * @param {string} input * @param {Object[]} args - * @returns {string} The input having been hashed with BLAKE2s, HEX encoded. + * @returns {string} The input having been hashed with BLAKE2s in the encoding format speicifed. */ run(input, args) { - const [outSize] = args; - return blakejs.blake2sHex(input, null, outSize / 8); + const [outSize, outFormat] = args; + switch (outFormat) { + case "Hex": + return blakejs.blake2sHex(input, null, outSize / 8); + case "Base64": + return toBase64(blakejs.blake2s(input, null, outSize / 8)); + case "Raw": + return Utils.arrayBufferToStr(blakejs.blake2s(input, null, outSize / 8).buffer); + default: + return new OperationError("Unsupported Output Type"); + } } } diff --git a/tests/operations/tests/BLAKE2b.mjs b/tests/operations/tests/BLAKE2b.mjs index 41d47f23..0c05cd76 100644 --- a/tests/operations/tests/BLAKE2b.mjs +++ b/tests/operations/tests/BLAKE2b.mjs @@ -2,7 +2,7 @@ * BitwiseOp tests * * @author h345983745 - * @copyright Crown Copyright 2017 + * @copyright Crown Copyright 2019 * @license Apache-2.0 */ import TestRegister from "../TestRegister"; @@ -14,7 +14,7 @@ TestRegister.addTests([ expectedOutput: "4386a08a265111c9896f56456e2cb61a64239115c4784cf438e36cc851221972da3fb0115f73cd02486254001f878ab1fd126aac69844ef1c1ca152379d0a9bd", recipeConfig: [ { "op": "BLAKE2b", - "args": ["512"] } + "args": ["512", "Hex"] } ] }, { @@ -23,7 +23,7 @@ TestRegister.addTests([ expectedOutput: "4d388e82ca8f866e606b6f6f0be910abd62ad6e98c0adfc27cf35acf948986d5c5b9c18b6f47261e1e679eb98edf8e2d", recipeConfig: [ { "op": "BLAKE2b", - "args": ["384"] } + "args": ["384", "Hex"] } ] }, { @@ -32,7 +32,7 @@ TestRegister.addTests([ expectedOutput: "1dc01772ee0171f5f614c673e3c7fa1107a8cf727bdf5a6dadb379e93c0d1d00", recipeConfig: [ { "op": "BLAKE2b", - "args": ["256"] } + "args": ["256", "Hex"] } ] }, { @@ -41,7 +41,7 @@ TestRegister.addTests([ expectedOutput: "6a8489e6fd6e51fae12ab271ec7fc8134dd5d737", recipeConfig: [ { "op": "BLAKE2b", - "args": ["160"] } + "args": ["160", "Hex"] } ] } ]); diff --git a/tests/operations/tests/BLAKE2s.mjs b/tests/operations/tests/BLAKE2s.mjs index 092ac29c..80771430 100755 --- a/tests/operations/tests/BLAKE2s.mjs +++ b/tests/operations/tests/BLAKE2s.mjs @@ -2,7 +2,7 @@ * BitwiseOp tests * * @author h345983745 - * @copyright Crown Copyright 2017 + * @copyright Crown Copyright 2019 * @license Apache-2.0 */ import TestRegister from "../TestRegister"; @@ -14,7 +14,7 @@ TestRegister.addTests([ expectedOutput: "7706af019148849e516f95ba630307a2018bb7bf03803eca5ed7ed2c3c013513", recipeConfig: [ { "op": "BLAKE2s", - "args": ["256"] } + "args": ["256", "Hex"] } ] }, { @@ -23,7 +23,7 @@ TestRegister.addTests([ expectedOutput: "0e4fcfc2ee0097ac1d72d70b595a39e09a3c7c7e", recipeConfig: [ { "op": "BLAKE2s", - "args": ["160"] } + "args": ["160", "Hex"] } ] }, { @@ -32,7 +32,7 @@ TestRegister.addTests([ expectedOutput: "9964ee6f36126626bf864363edfa96f6", recipeConfig: [ { "op": "BLAKE2s", - "args": ["128"] } + "args": ["128", "Hex"] } ] } ]); From 903ea4522810b3a4729c660f65ab98ed81191971 Mon Sep 17 00:00:00 2001 From: h345983745 Date: Tue, 26 Mar 2019 21:22:59 +0000 Subject: [PATCH 6/9] Update Generate All Hashes --- src/core/operations/GenerateAllHashes.mjs | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/core/operations/GenerateAllHashes.mjs b/src/core/operations/GenerateAllHashes.mjs index 1fb09b5a..3453302f 100644 --- a/src/core/operations/GenerateAllHashes.mjs +++ b/src/core/operations/GenerateAllHashes.mjs @@ -90,14 +90,14 @@ class GenerateAllHashes extends Operation { "\nWhirlpool: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool"]) + "\nSSDEEP: " + (new SSDEEP()).run(str) + "\nCTPH: " + (new CTPH()).run(str) + - "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512"]) + - "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384"]) + - "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256"]) + - "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160"]) + - "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128"]) + - "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256"]) + - "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160"]) + - "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128"]) + + "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512", "Hex"]) + + "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384", "Hex"]) + + "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256", "Hex"]) + + "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160", "Hex"]) + + "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128", "Hex"]) + + "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256", "Hex"]) + + "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160", "Hex"]) + + "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128", "Hex"]) + "\n\nChecksums:" + "\nFletcher-8: " + (new Fletcher8Checksum).run(byteArray, []) + "\nFletcher-16: " + (new Fletcher16Checksum).run(byteArray, []) + From 3950dba2c5278451a8ead362ddfa406c147c871f Mon Sep 17 00:00:00 2001 From: h345983745 Date: Sun, 31 Mar 2019 18:32:53 +0100 Subject: [PATCH 7/9] Added Key Option --- src/core/operations/BLAKE2b.mjs | 18 ++++++++++++++---- src/core/operations/BLAKE2s.mjs | 18 +++++++++++++++--- src/core/operations/GenerateAllHashes.mjs | 16 ++++++++-------- tests/operations/tests/BLAKE2b.mjs | 17 +++++++++++++---- tests/operations/tests/BLAKE2s.mjs | 15 ++++++++++++--- 5 files changed, 62 insertions(+), 22 deletions(-) diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index 7124cd52..62709a93 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -36,6 +36,11 @@ class BLAKE2b extends Operation { "name": "Output Encoding", "type": "option", "value": ["Hex", "Base64", "Raw"] + }, { + "name": "Key", + "type": "toggleString", + "value": "", + "toggleValues": ["UTF8", "Decimal", "Base64", "Hex", "Latin1"] } ]; } @@ -47,14 +52,19 @@ class BLAKE2b extends Operation { */ run(input, args) { const [outSize, outFormat] = args; - + let key = Utils.convertToByteArray(args[2].string || "", args[2].option); + if (key.length === 0){ + key = null; + } else if (key.length > 64){ + throw new OperationError(["Key cannot be greater than 64 bytes", "It is currently " + key.length +" bytes."].join("\n")); + } switch (outFormat) { case "Hex": - return blakejs.blake2bHex(input, null, outSize / 8); + return blakejs.blake2bHex(input, key, outSize / 8); case "Base64": - return toBase64(blakejs.blake2b(input, null, outSize / 8)); + return toBase64(blakejs.blake2b(input, key, outSize / 8)); case "Raw": - return Utils.arrayBufferToStr(blakejs.blake2b(input, null, outSize / 8).buffer); + return Utils.arrayBufferToStr(blakejs.blake2b(input, key, outSize / 8).buffer); default: return new OperationError("Unsupported Output Type"); } diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index 2e7f5dd9..0ded5eac 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -35,6 +35,12 @@ class BLAKE2s extends Operation { "name": "Output Encoding", "type": "option", "value": ["Hex", "Base64", "Raw"] + }, + { + "name": "Key", + "type": "toggleString", + "value": "", + "toggleValues": ["UTF8", "Decimal", "Base64", "Hex", "Latin1"] } ]; } @@ -46,13 +52,19 @@ class BLAKE2s extends Operation { */ run(input, args) { const [outSize, outFormat] = args; + let key = Utils.convertToByteArray(args[2].string || "", args[2].option); + if (key.length === 0){ + key = null; + } else if (key.length > 32){ + throw new OperationError(["Key cannot be greater than 32 bytes", "It is currently " + key.length +" bytes."].join("\n")); + } switch (outFormat) { case "Hex": - return blakejs.blake2sHex(input, null, outSize / 8); + return blakejs.blake2sHex(input, key, outSize / 8); case "Base64": - return toBase64(blakejs.blake2s(input, null, outSize / 8)); + return toBase64(blakejs.blake2s(input, key, outSize / 8)); case "Raw": - return Utils.arrayBufferToStr(blakejs.blake2s(input, null, outSize / 8).buffer); + return Utils.arrayBufferToStr(blakejs.blake2s(input, key, outSize / 8).buffer); default: return new OperationError("Unsupported Output Type"); } diff --git a/src/core/operations/GenerateAllHashes.mjs b/src/core/operations/GenerateAllHashes.mjs index 3453302f..53a6fcf9 100644 --- a/src/core/operations/GenerateAllHashes.mjs +++ b/src/core/operations/GenerateAllHashes.mjs @@ -90,14 +90,14 @@ class GenerateAllHashes extends Operation { "\nWhirlpool: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool"]) + "\nSSDEEP: " + (new SSDEEP()).run(str) + "\nCTPH: " + (new CTPH()).run(str) + - "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512", "Hex"]) + - "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384", "Hex"]) + - "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256", "Hex"]) + - "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160", "Hex"]) + - "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128", "Hex"]) + - "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256", "Hex"]) + - "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160", "Hex"]) + - "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128", "Hex"]) + + "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128", "Hex", {string: "", option: "UTF8"}]) + "\n\nChecksums:" + "\nFletcher-8: " + (new Fletcher8Checksum).run(byteArray, []) + "\nFletcher-16: " + (new Fletcher16Checksum).run(byteArray, []) + diff --git a/tests/operations/tests/BLAKE2b.mjs b/tests/operations/tests/BLAKE2b.mjs index 0c05cd76..94c4fab9 100644 --- a/tests/operations/tests/BLAKE2b.mjs +++ b/tests/operations/tests/BLAKE2b.mjs @@ -14,7 +14,7 @@ TestRegister.addTests([ expectedOutput: "4386a08a265111c9896f56456e2cb61a64239115c4784cf438e36cc851221972da3fb0115f73cd02486254001f878ab1fd126aac69844ef1c1ca152379d0a9bd", recipeConfig: [ { "op": "BLAKE2b", - "args": ["512", "Hex"] } + "args": ["512", "Hex", {string: "", option: "UTF8"}] } ] }, { @@ -23,7 +23,7 @@ TestRegister.addTests([ expectedOutput: "4d388e82ca8f866e606b6f6f0be910abd62ad6e98c0adfc27cf35acf948986d5c5b9c18b6f47261e1e679eb98edf8e2d", recipeConfig: [ { "op": "BLAKE2b", - "args": ["384", "Hex"] } + "args": ["384", "Hex", {string: "", option: "UTF8"}] } ] }, { @@ -32,7 +32,7 @@ TestRegister.addTests([ expectedOutput: "1dc01772ee0171f5f614c673e3c7fa1107a8cf727bdf5a6dadb379e93c0d1d00", recipeConfig: [ { "op": "BLAKE2b", - "args": ["256", "Hex"] } + "args": ["256", "Hex", {string: "", option: "UTF8"}] } ] }, { @@ -41,7 +41,16 @@ TestRegister.addTests([ expectedOutput: "6a8489e6fd6e51fae12ab271ec7fc8134dd5d737", recipeConfig: [ { "op": "BLAKE2b", - "args": ["160", "Hex"] } + "args": ["160", "Hex", {string: "", option: "UTF8"}] } + ] + }, + { + name: "BLAKE2b: Key Test", + input: "message data", + expectedOutput: "3d363ff7401e02026f4a4687d4863ced", + recipeConfig: [ + { "op": "BLAKE2b", + "args": ["128", "Hex", {string: "pseudorandom key", option: "UTF8"}] } ] } ]); diff --git a/tests/operations/tests/BLAKE2s.mjs b/tests/operations/tests/BLAKE2s.mjs index 80771430..09d53b6a 100755 --- a/tests/operations/tests/BLAKE2s.mjs +++ b/tests/operations/tests/BLAKE2s.mjs @@ -14,7 +14,7 @@ TestRegister.addTests([ expectedOutput: "7706af019148849e516f95ba630307a2018bb7bf03803eca5ed7ed2c3c013513", recipeConfig: [ { "op": "BLAKE2s", - "args": ["256", "Hex"] } + "args": ["256", "Hex", {string: "", option: "UTF8"}] } ] }, { @@ -23,7 +23,7 @@ TestRegister.addTests([ expectedOutput: "0e4fcfc2ee0097ac1d72d70b595a39e09a3c7c7e", recipeConfig: [ { "op": "BLAKE2s", - "args": ["160", "Hex"] } + "args": ["160", "Hex", {string: "", option: "UTF8"}] } ] }, { @@ -32,7 +32,16 @@ TestRegister.addTests([ expectedOutput: "9964ee6f36126626bf864363edfa96f6", recipeConfig: [ { "op": "BLAKE2s", - "args": ["128", "Hex"] } + "args": ["128", "Hex", {string: "", option: "UTF8"}] } + ] + }, + { + name: "BLAKE2s: Key Test", + input: "Hello World", + expectedOutput: "9964ee6f36126626bf864363edfa96f6", + recipeConfig: [ + { "op": "BLAKE2s", + "args": ["128", "Hex", {string: "", option: "UTF8"}] } ] } ]); From bb8c305fc85ac81520f28f7c9b40d0b67cbb7a9e Mon Sep 17 00:00:00 2001 From: h345983745 Date: Sun, 31 Mar 2019 18:46:29 +0100 Subject: [PATCH 8/9] Updated description --- src/core/operations/BLAKE2b.mjs | 6 ++++-- src/core/operations/BLAKE2s.mjs | 6 ++++-- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index 62709a93..39e9b5fd 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -23,7 +23,9 @@ class BLAKE2b extends Operation { this.name = "BLAKE2b"; this.module = "Hashing"; - this.description = "Performs BLAKE2b hashing on the input. Returns the output HEX encoded."; + this.description = `Performs BLAKE2b hashing on the input. +

BLAKE2b is a flavour of the BLAKE cryptographic hash function that is optimized for 64-bit platforms and produces digests of any size between 1 and 64 bytes. +

Supports the use of an optional key.`; this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2b_algorithm"; this.inputType = "string"; this.outputType = "string"; @@ -56,7 +58,7 @@ class BLAKE2b extends Operation { if (key.length === 0){ key = null; } else if (key.length > 64){ - throw new OperationError(["Key cannot be greater than 64 bytes", "It is currently " + key.length +" bytes."].join("\n")); + throw new OperationError(["Key cannot be greater than 64 bytes", "It is currently " + key.length + " bytes."].join("\n")); } switch (outFormat) { case "Hex": diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index 0ded5eac..7ddb9d2b 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -22,7 +22,9 @@ class BLAKE2s extends Operation { this.name = "BLAKE2s"; this.module = "Hashing"; - this.description = "Performs BLAKE2s hashing on the input. Returns the output HEX encoded."; + this.description = `Performs BLAKE2s hashing on the input. +

BLAKE2s is a flavour of the BLAKE cryptographic hash function that is optimized for 8 to 32-bit platforms and produces digests of any size between 1 and 32 bytes. +

Supports the use of an optional key.`; this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; this.inputType = "string"; this.outputType = "string"; @@ -56,7 +58,7 @@ class BLAKE2s extends Operation { if (key.length === 0){ key = null; } else if (key.length > 32){ - throw new OperationError(["Key cannot be greater than 32 bytes", "It is currently " + key.length +" bytes."].join("\n")); + throw new OperationError(["Key cannot be greater than 32 bytes", "It is currently " + key.length + " bytes."].join("\n")); } switch (outFormat) { case "Hex": From 3dc5b5c31af7689c8dd82795da37cc6b019c5849 Mon Sep 17 00:00:00 2001 From: n1474335 Date: Sun, 31 Mar 2019 22:40:54 +0100 Subject: [PATCH 9/9] Changed input type for BLAKE hashing ops to ArrayBuffer and tidied --- CHANGELOG.md | 6 ++++++ src/core/config/Categories.json | 6 +++--- src/core/operations/BLAKE2b.mjs | 10 ++++++---- src/core/operations/BLAKE2s.mjs | 15 +++++++++------ src/core/operations/GenerateAllHashes.mjs | 16 ++++++++-------- 5 files changed, 32 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d00c7d7d..3d177bb2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,10 @@ # Changelog All major and minor version changes will be documented in this file. Details of patch-level version changes can be found in [commit messages](https://github.com/gchq/CyberChef/commits/master). + +### [8.29.0] - 2019-03-31 +- 'BLAKE2s' and 'BLAKE2b' hashing operations added [@h345983745] | [#525] + ### [8.28.0] - 2019-03-31 - 'Heatmap Chart', 'Hex Density Chart', 'Scatter Chart' and 'Series Chart' operation added [@artemisbot] [@tlwr] | [#496] [#143] @@ -120,6 +124,7 @@ All major and minor version changes will be documented in this file. Details of +[8.29.0]: https://github.com/gchq/CyberChef/releases/tag/v8.29.0 [8.28.0]: https://github.com/gchq/CyberChef/releases/tag/v8.28.0 [8.27.0]: https://github.com/gchq/CyberChef/releases/tag/v8.27.0 [8.26.0]: https://github.com/gchq/CyberChef/releases/tag/v8.26.0 @@ -217,3 +222,4 @@ All major and minor version changes will be documented in this file. Details of [#496]: https://github.com/gchq/CyberChef/pull/496 [#506]: https://github.com/gchq/CyberChef/pull/506 [#516]: https://github.com/gchq/CyberChef/pull/516 +[#525]: https://github.com/gchq/CyberChef/pull/525 diff --git a/src/core/config/Categories.json b/src/core/config/Categories.json index c3ed15b0..e9451a28 100755 --- a/src/core/config/Categories.json +++ b/src/core/config/Categories.json @@ -297,6 +297,8 @@ "HAS-160", "Whirlpool", "Snefru", + "BLAKE2b", + "BLAKE2s", "SSDEEP", "CTPH", "Compare SSDEEP hashes", @@ -313,9 +315,7 @@ "Adler-32 Checksum", "CRC-16 Checksum", "CRC-32 Checksum", - "TCP/IP Checksum", - "BLAKE2b", - "BLAKE2s" + "TCP/IP Checksum" ] }, { diff --git a/src/core/operations/BLAKE2b.mjs b/src/core/operations/BLAKE2b.mjs index 39e9b5fd..60bca3b5 100644 --- a/src/core/operations/BLAKE2b.mjs +++ b/src/core/operations/BLAKE2b.mjs @@ -27,7 +27,7 @@ class BLAKE2b extends Operation {

BLAKE2b is a flavour of the BLAKE cryptographic hash function that is optimized for 64-bit platforms and produces digests of any size between 1 and 64 bytes.

Supports the use of an optional key.`; this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2b_algorithm"; - this.inputType = "string"; + this.inputType = "ArrayBuffer"; this.outputType = "string"; this.args = [ { @@ -48,18 +48,20 @@ class BLAKE2b extends Operation { } /** - * @param {string} input + * @param {ArrayBuffer} input * @param {Object[]} args * @returns {string} The input having been hashed with BLAKE2b in the encoding format speicifed. */ run(input, args) { const [outSize, outFormat] = args; let key = Utils.convertToByteArray(args[2].string || "", args[2].option); - if (key.length === 0){ + if (key.length === 0) { key = null; - } else if (key.length > 64){ + } else if (key.length > 64) { throw new OperationError(["Key cannot be greater than 64 bytes", "It is currently " + key.length + " bytes."].join("\n")); } + + input = new Uint8Array(input); switch (outFormat) { case "Hex": return blakejs.blake2bHex(input, key, outSize / 8); diff --git a/src/core/operations/BLAKE2s.mjs b/src/core/operations/BLAKE2s.mjs index 7ddb9d2b..72cf1988 100644 --- a/src/core/operations/BLAKE2s.mjs +++ b/src/core/operations/BLAKE2s.mjs @@ -9,6 +9,7 @@ import blakejs from "blakejs"; import OperationError from "../errors/OperationError"; import Utils from "../Utils"; import { toBase64 } from "../lib/Base64"; + /** * BLAKE2s Operation */ @@ -23,10 +24,10 @@ class BLAKE2s extends Operation { this.name = "BLAKE2s"; this.module = "Hashing"; this.description = `Performs BLAKE2s hashing on the input. -

BLAKE2s is a flavour of the BLAKE cryptographic hash function that is optimized for 8 to 32-bit platforms and produces digests of any size between 1 and 32 bytes. -

Supports the use of an optional key.`; +

BLAKE2s is a flavour of the BLAKE cryptographic hash function that is optimized for 8- to 32-bit platforms and produces digests of any size between 1 and 32 bytes. +

Supports the use of an optional key.`; this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2"; - this.inputType = "string"; + this.inputType = "ArrayBuffer"; this.outputType = "string"; this.args = [ { @@ -48,18 +49,20 @@ class BLAKE2s extends Operation { } /** - * @param {string} input + * @param {ArrayBuffer} input * @param {Object[]} args * @returns {string} The input having been hashed with BLAKE2s in the encoding format speicifed. */ run(input, args) { const [outSize, outFormat] = args; let key = Utils.convertToByteArray(args[2].string || "", args[2].option); - if (key.length === 0){ + if (key.length === 0) { key = null; - } else if (key.length > 32){ + } else if (key.length > 32) { throw new OperationError(["Key cannot be greater than 32 bytes", "It is currently " + key.length + " bytes."].join("\n")); } + + input = new Uint8Array(input); switch (outFormat) { case "Hex": return blakejs.blake2sHex(input, key, outSize / 8); diff --git a/src/core/operations/GenerateAllHashes.mjs b/src/core/operations/GenerateAllHashes.mjs index 53a6fcf9..6663d4e8 100644 --- a/src/core/operations/GenerateAllHashes.mjs +++ b/src/core/operations/GenerateAllHashes.mjs @@ -88,16 +88,16 @@ class GenerateAllHashes extends Operation { "\nWhirlpool-0: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool-0"]) + "\nWhirlpool-T: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool-T"]) + "\nWhirlpool: " + (new Whirlpool()).run(arrayBuffer, ["Whirlpool"]) + + "\nBLAKE2b-128: " + (new BLAKE2b).run(arrayBuffer, ["128", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-160: " + (new BLAKE2b).run(arrayBuffer, ["160", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-256: " + (new BLAKE2b).run(arrayBuffer, ["256", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-384: " + (new BLAKE2b).run(arrayBuffer, ["384", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2b-512: " + (new BLAKE2b).run(arrayBuffer, ["512", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-128: " + (new BLAKE2s).run(arrayBuffer, ["128", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-160: " + (new BLAKE2s).run(arrayBuffer, ["160", "Hex", {string: "", option: "UTF8"}]) + + "\nBLAKE2s-256: " + (new BLAKE2s).run(arrayBuffer, ["256", "Hex", {string: "", option: "UTF8"}]) + "\nSSDEEP: " + (new SSDEEP()).run(str) + "\nCTPH: " + (new CTPH()).run(str) + - "\nBLAKE2b-512: " + (new BLAKE2b).run(str, ["512", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2b-384: " + (new BLAKE2b).run(str, ["384", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2b-256: " + (new BLAKE2b).run(str, ["256", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2b-160: " + (new BLAKE2b).run(str, ["160", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2b-128: " + (new BLAKE2b).run(str, ["128", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2s-256: " + (new BLAKE2s).run(str, ["256", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2s-160: " + (new BLAKE2s).run(str, ["160", "Hex", {string: "", option: "UTF8"}]) + - "\nBLAKE2s-128: " + (new BLAKE2s).run(str, ["128", "Hex", {string: "", option: "UTF8"}]) + "\n\nChecksums:" + "\nFletcher-8: " + (new Fletcher8Checksum).run(byteArray, []) + "\nFletcher-16: " + (new Fletcher16Checksum).run(byteArray, []) +