mirror of
				https://github.com/therootcompany/keypairs.js.git
				synced 2024-11-16 17:29:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			127 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env node
 | |
| 'use strict';
 | |
| 
 | |
| var fs = require('fs');
 | |
| var Rasha = require('../rsa');
 | |
| var PEM = require('@root/pem');
 | |
| var ASN1 = require('@root/asn1');
 | |
| 
 | |
| var infile = process.argv[2];
 | |
| var format = process.argv[3];
 | |
| var msg = process.argv[4];
 | |
| var sign;
 | |
| if ('sign' === format) {
 | |
| 	sign = true;
 | |
| 	format = 'pkcs8';
 | |
| }
 | |
| 
 | |
| if (!infile) {
 | |
| 	infile = 'jwk';
 | |
| }
 | |
| 
 | |
| if (
 | |
| 	-1 !==
 | |
| 	['jwk', 'pem', 'json', 'der', 'pkcs1', 'pkcs8', 'spki'].indexOf(infile)
 | |
| ) {
 | |
| 	console.info('Generating new key...');
 | |
| 	Rasha.generate({
 | |
| 		format: infile,
 | |
| 		modulusLength: parseInt(format, 10) || 2048,
 | |
| 		encoding: parseInt(format, 10) ? null : format
 | |
| 	})
 | |
| 		.then(function (key) {
 | |
| 			if ('der' === infile || 'der' === format) {
 | |
| 				key.private = key.private.toString('binary');
 | |
| 				key.public = key.public.toString('binary');
 | |
| 			}
 | |
| 			console.info(key.private);
 | |
| 			console.info(key.public);
 | |
| 		})
 | |
| 		.catch(function (err) {
 | |
| 			console.error(err);
 | |
| 			process.exit(1);
 | |
| 		});
 | |
| 	return;
 | |
| }
 | |
| var key = fs.readFileSync(infile, 'ascii');
 | |
| 
 | |
| try {
 | |
| 	key = JSON.parse(key);
 | |
| } catch (e) {
 | |
| 	// ignore
 | |
| }
 | |
| 
 | |
| var thumbprint = 'thumbprint' === format;
 | |
| if (thumbprint) {
 | |
| 	format = 'public';
 | |
| }
 | |
| 
 | |
| if ('string' === typeof key) {
 | |
| 	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;
 | |
| 	}
 | |
| 	if (sign) {
 | |
| 		signMessage(key, msg);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	var pub = -1 !== ['public', 'spki', 'pkix'].indexOf(format);
 | |
| 	Rasha.import({ pem: key, public: pub || format })
 | |
| 		.then(function (jwk) {
 | |
| 			console.info(JSON.stringify(jwk, null, 2));
 | |
| 		})
 | |
| 		.catch(function (err) {
 | |
| 			console.error(err);
 | |
| 			process.exit(1);
 | |
| 		});
 | |
| } else {
 | |
| 	if (thumbprint) {
 | |
| 		Rasha.thumbprint({ jwk: key }).then(console.info);
 | |
| 		return;
 | |
| 	}
 | |
| 	Rasha.export({ jwk: key, format: format })
 | |
| 		.then(function (pem) {
 | |
| 			if (sign) {
 | |
| 				signMessage(pem, msg);
 | |
| 				return;
 | |
| 			}
 | |
| 			console.info(pem);
 | |
| 		})
 | |
| 		.catch(function (err) {
 | |
| 			console.error(err);
 | |
| 			process.exit(2);
 | |
| 		});
 | |
| }
 | |
| 
 | |
| 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.info(buf.toString('base64'));
 | |
| 	/*
 | |
|   Rasha.sign({ pem: pem, message: msg, alg: 'SHA256' }).then(function (sig) {
 | |
|   }).catch(function () {
 | |
|     console.error(err);
 | |
|     process.exit(3);
 | |
|   });
 | |
|   */
 | |
| }
 |