rasha.js/bin/rasha.js

110 lines
2.6 KiB
JavaScript
Raw Normal View History

2018-11-21 23:47:41 +00:00
#!/usr/bin/env node
'use strict';
2018-11-22 01:44:46 +00:00
2018-11-22 07:39:43 +00:00
var fs = require('fs');
var Rasha = require('../index.js');
var PEM = require('../lib/pem.js');
var ASN1 = require('../lib/asn1.js');
2018-11-22 00:25:05 +00:00
2018-11-22 07:39:43 +00:00
var infile = process.argv[2];
var format = process.argv[3];
2018-12-15 21:55:54 +00:00
var msg = process.argv[4];
var sign;
if ('sign' === format) {
sign = true;
format = 'pkcs8';
}
2018-11-21 23:47:41 +00:00
2018-11-24 08:33:12 +00:00
if (!infile) {
infile = 'jwk';
}
if (-1 !== [ 'jwk', 'pem', 'json', 'der', 'pkcs1', 'pkcs8', 'spki' ].indexOf(infile)) {
console.log("Generating new key...");
Rasha.generate({
format: infile
, modulusLength: parseInt(format, 10) || 2048
, encoding: parseInt(format, 10) ? null : format
}).then(function (key) {
2018-11-25 02:47:56 +00:00
if ('der' === infile || 'der' === format) {
key.private = key.private.toString('binary');
key.public = key.public.toString('binary');
}
2018-11-24 08:33:12 +00:00
console.log(key.private);
console.log(key.public);
2018-11-25 02:03:26 +00:00
}).catch(function (err) {
console.error(err);
process.exit(1);
2018-11-24 08:33:12 +00:00
});
return;
}
2018-11-22 07:39:43 +00:00
var key = fs.readFileSync(infile, 'ascii');
2018-11-21 23:47:41 +00:00
2018-11-22 07:39:43 +00:00
try {
key = JSON.parse(key);
} catch(e) {
// ignore
2018-11-21 23:47:41 +00:00
}
2019-02-07 07:08:32 +00:00
var thumbprint = ('thumbprint' === format);
if (thumbprint) {
format = 'public';
}
2018-11-22 07:39:43 +00:00
if ('string' === typeof key) {
2019-02-07 07:08:32 +00:00
if (thumbprint) {
Rasha.thumbprint({ pem: key }).then(console.info);
return;
}
if ('tpl' === format) {
var block = PEM.parseBlock(key);
var asn1 = ASN1.parse(block.der);
ASN1.tpl(asn1);
return;
}
2018-12-15 21:55:54 +00:00
if (sign) { signMessage(key, msg); return; }
2018-11-22 07:39:43 +00:00
var pub = (-1 !== [ 'public', 'spki', 'pkix' ].indexOf(format));
Rasha.import({ pem: key, public: (pub || format) }).then(function (jwk) {
2018-11-22 09:36:21 +00:00
console.info(JSON.stringify(jwk, null, 2));
2018-11-22 07:39:43 +00:00
}).catch(function (err) {
console.error(err);
process.exit(1);
});
} else {
2019-02-07 07:08:32 +00:00
if (thumbprint) {
Rasha.thumbprint({ jwk: key }).then(console.info);
return;
}
2018-11-22 07:39:43 +00:00
Rasha.export({ jwk: key, format: format }).then(function (pem) {
2018-12-15 21:55:54 +00:00
if (sign) { signMessage(pem, msg); return; }
2018-11-22 09:36:21 +00:00
console.info(pem);
2018-11-22 07:39:43 +00:00
}).catch(function (err) {
console.error(err);
process.exit(2);
2018-11-22 01:49:57 +00:00
});
}
2018-12-15 21:55:54 +00:00
function signMessage(pem, name) {
var msg;
try {
msg = fs.readFileSync(name);
} catch(e) {
console.warn("[info] input string did not exist as a file, signing the string itself");
msg = Buffer.from(name, 'binary');
}
var crypto = require('crypto');
var sign = crypto.createSign('SHA256');
sign.write(msg)
sign.end()
var buf = sign.sign(pem);
console.log(buf.toString('base64'));
/*
Rasha.sign({ pem: pem, message: msg, alg: 'SHA256' }).then(function (sig) {
}).catch(function () {
console.error(err);
process.exit(3);
});
*/
}