-
Notifications
You must be signed in to change notification settings - Fork 1
/
inlineSign.js
38 lines (33 loc) · 1.06 KB
/
inlineSign.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
const openpgp = require('./initOpenpgp');
const fs = require('fs');
const utils = require('./utils');
const KEY_CANNOT_SIGN = 79;
const inlineSign = async (keyfiles, withKeyPassword, as, armor) => {
const data = await utils.read_stdin();
const fn = as === 'clearsigned' ? 'createCleartextMessage' : 'createMessage';
const message = await openpgp[fn](
as === 'binary' ?
{ binary: data } :
{ text: data.toString('utf8') }
);
let signingKeys = await utils.load_keys(...keyfiles);
if (withKeyPassword) {
const keyPassword = fs.readFileSync(withKeyPassword, 'utf8');
signingKeys = await Promise.all(signingKeys.map(privateKey => openpgp.decryptKey({
privateKey,
passphrase: [keyPassword, keyPassword.trimEnd()]
})));
}
const options = {
message,
signingKeys,
format: armor ? 'armored' : 'binary'
};
openpgp.sign(options).then(async (signature) => {
process.stdout.write(signature);
}).catch((e) => {
console.error(e.message);
return process.exit(KEY_CANNOT_SIGN);
});
};
module.exports = inlineSign;