mirror of
https://gitea.com/actions/setup-java.git
synced 2024-11-01 09:30:31 +01:00
d34438b137
This deletes the secret key(s) and public keys(s) for the fingerprint of the installed GPG_PRIVATE_KEY. If the installed GPG_PRIVATE_KEY only contains a signing subkey without the primary private key, the --delete-secret-and-public-key will successfully delete the keys. Signed-off-by: BJ Hargrave <bj@hargrave.dev>
46 lines
1.1 KiB
TypeScript
46 lines
1.1 KiB
TypeScript
import * as fs from 'fs';
|
|
import * as path from 'path';
|
|
import * as io from '@actions/io';
|
|
import * as exec from '@actions/exec';
|
|
import * as util from './util';
|
|
import { ExecOptions } from '@actions/exec/lib/interfaces';
|
|
|
|
export const PRIVATE_KEY_FILE = path.join(util.getTempDir(), 'private-key.asc');
|
|
|
|
const PRIVATE_KEY_FINGERPRINT_REGEX = /\w{40}/;
|
|
|
|
export async function importKey(privateKey: string) {
|
|
fs.writeFileSync(PRIVATE_KEY_FILE, privateKey, {
|
|
encoding: 'utf-8',
|
|
flag: 'w'
|
|
});
|
|
|
|
let output = '';
|
|
|
|
const options: ExecOptions = {
|
|
silent: true,
|
|
listeners: {
|
|
stdout: (data: Buffer) => {
|
|
output += data.toString();
|
|
}
|
|
}
|
|
};
|
|
|
|
await exec.exec(
|
|
'gpg',
|
|
['--batch', '--import-options', 'import-show', '--import', PRIVATE_KEY_FILE],
|
|
options
|
|
);
|
|
|
|
await io.rmRF(PRIVATE_KEY_FILE);
|
|
|
|
const match = output.match(PRIVATE_KEY_FINGERPRINT_REGEX);
|
|
return match && match[0];
|
|
}
|
|
|
|
export async function deleteKey(keyFingerprint: string) {
|
|
await exec.exec('gpg', ['--batch', '--yes', '--delete-secret-and-public-key', keyFingerprint], {
|
|
silent: true
|
|
});
|
|
}
|