Skip to content

Commit 31e758c

Browse files
committed
Attempt to make RSA key generation functional
1 parent f81ca3b commit 31e758c

File tree

5 files changed

+25
-9
lines changed

5 files changed

+25
-9
lines changed

package-lock.json

+6
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

package.json

+1
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,7 @@
6262
"postcss-import": "^12.0.0",
6363
"postcss-loader": "^2.1.6",
6464
"prompt": "^1.0.0",
65+
"raw-loader": "^0.5.1",
6566
"sass-loader": "^7.1.0",
6667
"sitemap": "^1.13.0",
6768
"style-loader": "^0.21.0",

src/core/operations/GenerateRSAKeyPair.mjs

+12-7
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66

77
import Operation from "../Operation";
88
import forge from "node-forge/dist/forge.min.js";
9+
import PrimeWorker from "node-forge/dist/prime.worker.min.js";
910

1011
/**
1112
* Generate RSA Key Pair operation
@@ -52,15 +53,19 @@ class GenerateRSAKeyPair extends Operation {
5253
* @returns {string}
5354
*/
5455
async run(input, args) {
55-
const [keyLength, outputFormat] = args
56+
const [keyLength, outputFormat] = args;
57+
let workerScript;
5658

5759
return new Promise((resolve, reject) => {
58-
forge.pki.rsa.generateKeyPair({ bits: Number(keyLength), workers: 2 }, (err, keypair) => {
59-
if (err) return reject(err)
60+
if (ENVIRONMENT_IS_WORKER || window) {
61+
workerScript = ENVIRONMENT_IS_WORKER() ? self.URL.createObjectURL(new Blob([PrimeWorker])) : window.URL.createObjectURL(new Blob([PrimeWorker]));
62+
}
63+
forge.pki.rsa.generateKeyPair({ bits: Number(keyLength), workers: 2, workerScript}, (err, keypair) => {
64+
if (err) return reject(err);
6065

6166
let result;
6267

63-
switch(outputFormat) {
68+
switch (outputFormat) {
6469
case "PEM":
6570
result = forge.pki.publicKeyToPem(keypair.publicKey) + "\n" + forge.pki.privateKeyToPem(keypair.privateKey);
6671
break;
@@ -70,11 +75,11 @@ class GenerateRSAKeyPair extends Operation {
7075
case "DER":
7176
result = forge.asn1.toDer(forge.pki.privateKeyToAsn1(keypair.privateKey)).getBytes();
7277
break;
73-
};
78+
}
7479

7580
resolve(result);
76-
})
77-
})
81+
});
82+
});
7883
}
7984

8085
}

src/core/operations/RSASign.mjs

+2-2
Original file line numberDiff line numberDiff line change
@@ -49,10 +49,10 @@ class RSASign extends Operation {
4949
const privateKey = forge.pki.decryptRsaPrivateKey(key, password);
5050

5151
const md = forge.md.sha1.create();
52-
md.update(input, 'utf8');
52+
md.update(input, "utf8");
5353
const signature = privateKey.sign(md);
5454

55-
return signature.split('').map(char => char.charCodeAt());
55+
return signature.split("").map(char => char.charCodeAt());
5656
}
5757

5858
}

webpack.config.js

+4
Original file line numberDiff line numberDiff line change
@@ -61,6 +61,10 @@ module.exports = {
6161
test: /forge.min.js$/,
6262
loader: "imports-loader?jQuery=>null"
6363
},
64+
{
65+
test: /prime.worker.min.js$/,
66+
use: "raw-loader"
67+
},
6468
{
6569
test: /bootstrap-material-design/,
6670
loader: "imports-loader?Popper=popper.js/dist/umd/popper.js"

0 commit comments

Comments
 (0)