import * as openpgp from 'openpgp'; import addressparser from 'addressparser'; export interface PrivateKey { fingerprint: string; keyID: string; name: string; email: string; creationTime: Date; } export interface KeyPair { publicKey: string; privateKey: string; } export const readPrivateKey = async (key: string): Promise => { const privateKey = await openpgp.readKey({ armoredKey: (await isArmored(key)) ? key : Buffer.from(key, 'base64').toString() }); const address = await privateKey.getPrimaryUser().then(primaryUser => { return addressparser(primaryUser.user.userID?.userID)[0]; }); return { fingerprint: privateKey.getFingerprint().toUpperCase(), keyID: await privateKey.getEncryptionKey().then(encKey => { // @ts-ignore return encKey?.getKeyID().toHex().toUpperCase(); }), name: address.name, email: address.address, creationTime: privateKey.getCreationTime() }; }; export const generateKeyPair = async (name: string, email: string, passphrase: string, type?: 'ecc' | 'rsa'): Promise => { const keyPair = await openpgp.generateKey({ userIDs: [{name: name, email: email}], passphrase: passphrase, type: type }); return { publicKey: keyPair.publicKey.replace(/\r\n/g, '\n').trim(), privateKey: keyPair.privateKey.replace(/\r\n/g, '\n').trim() }; }; export const isArmored = async (text: string): Promise => { return text.trimLeft().startsWith('---'); };