2019-03-26 20:09:57 +01:00
|
|
|
/**
|
2019-03-26 20:13:00 +01:00
|
|
|
* @author h345983745
|
2019-03-26 20:09:57 +01:00
|
|
|
* @copyright Crown Copyright 2019
|
|
|
|
* @license Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
import Operation from "../Operation";
|
|
|
|
import blakejs from "blakejs";
|
2019-03-26 22:12:03 +01:00
|
|
|
import OperationError from "../errors/OperationError";
|
|
|
|
import Utils from "../Utils";
|
|
|
|
import { toBase64 } from "../lib/Base64";
|
2019-03-26 20:09:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.";
|
2019-03-26 21:32:42 +01:00
|
|
|
this.infoURL = "https://wikipedia.org/wiki/BLAKE_(hash_function)#BLAKE2b_algorithm";
|
2019-03-26 20:09:57 +01:00
|
|
|
this.inputType = "string";
|
|
|
|
this.outputType = "string";
|
|
|
|
this.args = [
|
|
|
|
{
|
|
|
|
"name": "Size",
|
|
|
|
"type": "option",
|
|
|
|
"value": ["512", "384", "256", "160", "128"]
|
2019-03-26 22:12:03 +01:00
|
|
|
}, {
|
|
|
|
"name": "Output Encoding",
|
|
|
|
"type": "option",
|
|
|
|
"value": ["Hex", "Base64", "Raw"]
|
2019-03-31 19:32:53 +02:00
|
|
|
}, {
|
|
|
|
"name": "Key",
|
|
|
|
"type": "toggleString",
|
|
|
|
"value": "",
|
|
|
|
"toggleValues": ["UTF8", "Decimal", "Base64", "Hex", "Latin1"]
|
2019-03-26 20:09:57 +01:00
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} input
|
|
|
|
* @param {Object[]} args
|
2019-03-26 22:12:03 +01:00
|
|
|
* @returns {string} The input having been hashed with BLAKE2b in the encoding format speicifed.
|
2019-03-26 20:09:57 +01:00
|
|
|
*/
|
|
|
|
run(input, args) {
|
2019-03-26 22:12:03 +01:00
|
|
|
const [outSize, outFormat] = args;
|
2019-03-31 19:32:53 +02:00
|
|
|
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"));
|
|
|
|
}
|
2019-03-26 22:12:03 +01:00
|
|
|
switch (outFormat) {
|
|
|
|
case "Hex":
|
2019-03-31 19:32:53 +02:00
|
|
|
return blakejs.blake2bHex(input, key, outSize / 8);
|
2019-03-26 22:12:03 +01:00
|
|
|
case "Base64":
|
2019-03-31 19:32:53 +02:00
|
|
|
return toBase64(blakejs.blake2b(input, key, outSize / 8));
|
2019-03-26 22:12:03 +01:00
|
|
|
case "Raw":
|
2019-03-31 19:32:53 +02:00
|
|
|
return Utils.arrayBufferToStr(blakejs.blake2b(input, key, outSize / 8).buffer);
|
2019-03-26 22:12:03 +01:00
|
|
|
default:
|
|
|
|
return new OperationError("Unsupported Output Type");
|
|
|
|
}
|
2019-03-26 20:09:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export default BLAKE2b;
|