mirror of
https://github.com/gchq/CyberChef.git
synced 2025-04-21 15:26:16 -04:00
Add Argon2 hash compare operation
This commit is contained in:
parent
2fab1028c5
commit
bca4c34b3a
3 changed files with 66 additions and 0 deletions
|
@ -380,6 +380,7 @@
|
||||||
"Bcrypt parse",
|
"Bcrypt parse",
|
||||||
"Scrypt",
|
"Scrypt",
|
||||||
"Argon2",
|
"Argon2",
|
||||||
|
"Argon2 compare",
|
||||||
"NT Hash",
|
"NT Hash",
|
||||||
"LM Hash",
|
"LM Hash",
|
||||||
"Fletcher-8 Checksum",
|
"Fletcher-8 Checksum",
|
||||||
|
|
58
src/core/operations/Argon2Compare.mjs
Normal file
58
src/core/operations/Argon2Compare.mjs
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/**
|
||||||
|
* @author Tan Zhen Yong [tzy@beyondthesprawl.com]
|
||||||
|
* @copyright Crown Copyright 2019
|
||||||
|
* @license Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
import Operation from "../Operation.mjs";
|
||||||
|
import argon2 from "argon2-browser";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Argon2 compare operation
|
||||||
|
*/
|
||||||
|
class Argon2Compare extends Operation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Argon2Compare constructor
|
||||||
|
*/
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
|
||||||
|
this.name = "Argon2 compare";
|
||||||
|
this.module = "Crypto";
|
||||||
|
this.description = "Tests whether the input matches the given Argon2 hash. To test multiple possible passwords, use the 'Fork' operation.";
|
||||||
|
this.infoURL = "https://wikipedia.org/wiki/Argon2";
|
||||||
|
this.inputType = "string";
|
||||||
|
this.outputType = "string";
|
||||||
|
this.args = [
|
||||||
|
{
|
||||||
|
"name": "Hash",
|
||||||
|
"type": "string",
|
||||||
|
"value": ""
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string} input
|
||||||
|
* @param {Object[]} args
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
async run(input, args) {
|
||||||
|
const encoded = args[0];
|
||||||
|
|
||||||
|
try {
|
||||||
|
await argon2.verify({
|
||||||
|
pass: input,
|
||||||
|
encoded
|
||||||
|
});
|
||||||
|
|
||||||
|
return `Match: ${input}`;
|
||||||
|
} catch (err) {
|
||||||
|
return "No match";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Argon2Compare;
|
|
@ -138,6 +138,13 @@ Tiger-128`;
|
||||||
assert.strictEqual(result.toString(), "$argon2i$v=19$m=4096,t=3,p=1$c29tZXNhbHQ$s43my9eBljQADuF/LWCG8vGqwAJzOorKQ0Yog8jFvbw");
|
assert.strictEqual(result.toString(), "$argon2i$v=19$m=4096,t=3,p=1$c29tZXNhbHQ$s43my9eBljQADuF/LWCG8vGqwAJzOorKQ0Yog8jFvbw");
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
it("argon2 compare", async () => {
|
||||||
|
const result = await chef.argon2Compare("argon2password", {
|
||||||
|
hash: "$argon2i$v=19$m=4096,t=3,p=1$c29tZXNhbHQ$s43my9eBljQADuF/LWCG8vGqwAJzOorKQ0Yog8jFvbw"
|
||||||
|
});
|
||||||
|
assert.strictEqual(result.toString(), "Match: argon2password");
|
||||||
|
}),
|
||||||
|
|
||||||
it("Bcrypt", async () => {
|
it("Bcrypt", async () => {
|
||||||
const result = await chef.bcrypt("Put a Sock In It");
|
const result = await chef.bcrypt("Put a Sock In It");
|
||||||
const strResult = result.toString();
|
const strResult = result.toString();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue