Skip to content

Commit 47c85a1

Browse files
committed
Added message format arg to RSA Verify operation
1 parent d3adfc7 commit 47c85a1

File tree

1 file changed

+9
-2
lines changed

1 file changed

+9
-2
lines changed

src/core/operations/RSAVerify.mjs

+9-2
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@ import Operation from "../Operation.mjs";
88
import OperationError from "../errors/OperationError.mjs";
99
import forge from "node-forge";
1010
import { MD_ALGORITHMS } from "../lib/RSA.mjs";
11+
import Utils from "../Utils.mjs";
1112

1213
/**
1314
* RSA Verify operation
@@ -37,6 +38,11 @@ class RSAVerify extends Operation {
3738
type: "text",
3839
value: ""
3940
},
41+
{
42+
name: "Message format",
43+
type: "option",
44+
value: ["Raw", "Hex", "Base64"]
45+
},
4046
{
4147
name: "Message Digest Algorithm",
4248
type: "option",
@@ -51,7 +57,7 @@ class RSAVerify extends Operation {
5157
* @returns {string}
5258
*/
5359
run(input, args) {
54-
const [pemKey, message, mdAlgo] = args;
60+
const [pemKey, message, format, mdAlgo] = args;
5561
if (pemKey.replace("-----BEGIN RSA PUBLIC KEY-----", "").length === 0) {
5662
throw new OperationError("Please enter a public key.");
5763
}
@@ -60,7 +66,8 @@ class RSAVerify extends Operation {
6066
const pubKey = forge.pki.publicKeyFromPem(pemKey);
6167
// Generate message digest
6268
const md = MD_ALGORITHMS[mdAlgo].create();
63-
md.update(message, "raw");
69+
const messageStr = Utils.convertToByteString(message, format);
70+
md.update(messageStr, "raw");
6471
// Compare signed message digest and generated message digest
6572
const result = pubKey.verify(md.digest().bytes(), input);
6673
return result ? "Verified OK" : "Verification Failure";

0 commit comments

Comments
 (0)