Skip to content

Commit

Permalink
Attempt to make RSA key generation functional
Browse files Browse the repository at this point in the history
  • Loading branch information
mattnotmitt committed Aug 31, 2018
1 parent f81ca3b commit 31e758c
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 9 deletions.
6 changes: 6 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@
"postcss-import": "^12.0.0",
"postcss-loader": "^2.1.6",
"prompt": "^1.0.0",
"raw-loader": "^0.5.1",
"sass-loader": "^7.1.0",
"sitemap": "^1.13.0",
"style-loader": "^0.21.0",
Expand Down
19 changes: 12 additions & 7 deletions src/core/operations/GenerateRSAKeyPair.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

import Operation from "../Operation";
import forge from "node-forge/dist/forge.min.js";
import PrimeWorker from "node-forge/dist/prime.worker.min.js";

/**
* Generate RSA Key Pair operation
Expand Down Expand Up @@ -52,15 +53,19 @@ class GenerateRSAKeyPair extends Operation {
* @returns {string}
*/
async run(input, args) {
const [keyLength, outputFormat] = args
const [keyLength, outputFormat] = args;
let workerScript;

return new Promise((resolve, reject) => {
forge.pki.rsa.generateKeyPair({ bits: Number(keyLength), workers: 2 }, (err, keypair) => {
if (err) return reject(err)
if (ENVIRONMENT_IS_WORKER || window) {
workerScript = ENVIRONMENT_IS_WORKER() ? self.URL.createObjectURL(new Blob([PrimeWorker])) : window.URL.createObjectURL(new Blob([PrimeWorker]));
}
forge.pki.rsa.generateKeyPair({ bits: Number(keyLength), workers: 2, workerScript}, (err, keypair) => {
if (err) return reject(err);

let result;

switch(outputFormat) {
switch (outputFormat) {
case "PEM":
result = forge.pki.publicKeyToPem(keypair.publicKey) + "\n" + forge.pki.privateKeyToPem(keypair.privateKey);
break;
Expand All @@ -70,11 +75,11 @@ class GenerateRSAKeyPair extends Operation {
case "DER":
result = forge.asn1.toDer(forge.pki.privateKeyToAsn1(keypair.privateKey)).getBytes();
break;
};
}

resolve(result);
})
})
});
});
}

}
Expand Down
4 changes: 2 additions & 2 deletions src/core/operations/RSASign.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -49,10 +49,10 @@ class RSASign extends Operation {
const privateKey = forge.pki.decryptRsaPrivateKey(key, password);

const md = forge.md.sha1.create();
md.update(input, 'utf8');
md.update(input, "utf8");
const signature = privateKey.sign(md);

return signature.split('').map(char => char.charCodeAt());
return signature.split("").map(char => char.charCodeAt());
}

}
Expand Down
4 changes: 4 additions & 0 deletions webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,10 @@ module.exports = {
test: /forge.min.js$/,
loader: "imports-loader?jQuery=>null"
},
{
test: /prime.worker.min.js$/,
use: "raw-loader"
},
{
test: /bootstrap-material-design/,
loader: "imports-loader?Popper=popper.js/dist/umd/popper.js"
Expand Down

0 comments on commit 31e758c

Please sign in to comment.