mirror of
https://github.com/crazy-max/ghaction-import-gpg.git
synced 2025-01-19 14:24:45 +01:00
105 lines
3.3 KiB
TypeScript
105 lines
3.3 KiB
TypeScript
import * as core from '@actions/core';
|
|
import * as git from './git';
|
|
import * as gpg from './gpg';
|
|
import * as openpgp from './openpgp';
|
|
import * as stateHelper from './state-helper';
|
|
import os from 'os';
|
|
|
|
async function run(): Promise<void> {
|
|
try {
|
|
if (os.platform() == 'win32') {
|
|
core.setFailed('Windows platform not supported');
|
|
return;
|
|
}
|
|
|
|
if (!process.env.SIGNING_KEY) {
|
|
core.setFailed('Signing key required');
|
|
return;
|
|
}
|
|
|
|
const git_gpgsign = /true/i.test(core.getInput('git_gpgsign'));
|
|
const git_committer_name: string =
|
|
core.getInput('git_committer_name') || process.env['GITHUB_ACTOR'] || 'github-actions';
|
|
const git_committer_email: string =
|
|
core.getInput('git_committer_email') || `${git_committer_name}@users.noreply.github.com`;
|
|
|
|
core.info('📣 GnuPG info');
|
|
const version = await gpg.getVersion();
|
|
const dirs = await gpg.getDirs();
|
|
core.info(`Version : ${version.gnupg} (libgcrypt ${version.libgcrypt})`);
|
|
core.info(`Libdir : ${dirs.libdir}`);
|
|
core.info(`Libexecdir : ${dirs.libexecdir}`);
|
|
core.info(`Datadir : ${dirs.datadir}`);
|
|
core.info(`Homedir : ${dirs.homedir}`);
|
|
|
|
core.info('🔮 Checking signing key');
|
|
const privateKey = await openpgp.readPrivateKey(process.env.SIGNING_KEY);
|
|
core.debug(`Fingerprint : ${privateKey.fingerprint}`);
|
|
core.debug(`KeyID : ${privateKey.keyID}`);
|
|
core.debug(`Name : ${privateKey.name}`);
|
|
core.debug(`Email : ${privateKey.email}`);
|
|
core.debug(`CreationTime : ${privateKey.creationTime}`);
|
|
|
|
core.info('🔑 Importing secret key');
|
|
await gpg.importKey(process.env.SIGNING_KEY).then(stdout => {
|
|
core.debug(stdout);
|
|
});
|
|
|
|
if (process.env.PASSPHRASE) {
|
|
core.info('⚙️ Configuring GnuPG agent');
|
|
await gpg.configureAgent(gpg.agentConfig);
|
|
|
|
core.info('📌 Getting keygrip');
|
|
const keygrip = await gpg.getKeygrip(privateKey.fingerprint);
|
|
core.debug(`${keygrip}`);
|
|
|
|
core.info('🔓 Preset passphrase');
|
|
await gpg.presetPassphrase(keygrip, process.env.PASSPHRASE).then(stdout => {
|
|
core.debug(stdout);
|
|
});
|
|
}
|
|
|
|
if (git_gpgsign) {
|
|
core.info(`🔨 Configuring git committer to be ${git_committer_name} <${git_committer_email}>`);
|
|
if (git_committer_email != privateKey.email) {
|
|
core.setFailed('Committer email does not match GPG key user address');
|
|
return;
|
|
}
|
|
|
|
await git.setConfig('user.name', git_committer_name);
|
|
await git.setConfig('user.email', git_committer_email);
|
|
|
|
core.info('💎 Enable signing for this Git repository');
|
|
await git.enableCommitGpgsign();
|
|
await git.setUserSigningkey(privateKey.keyID);
|
|
}
|
|
} catch (error) {
|
|
core.setFailed(error.message);
|
|
}
|
|
}
|
|
|
|
async function cleanup(): Promise<void> {
|
|
if (!process.env.SIGNING_KEY) {
|
|
core.debug('Signing key is not defined. Skipping cleanup.');
|
|
return;
|
|
}
|
|
try {
|
|
core.info('🚿 Removing keys');
|
|
const privateKey = await openpgp.readPrivateKey(process.env.SIGNING_KEY);
|
|
await gpg.deleteKey(privateKey.fingerprint);
|
|
|
|
core.info('💀 Killing GnuPG agent');
|
|
await gpg.killAgent();
|
|
} catch (error) {
|
|
core.warning(error.message);
|
|
}
|
|
}
|
|
|
|
// Main
|
|
if (!stateHelper.IsPost) {
|
|
run();
|
|
}
|
|
// Post
|
|
else {
|
|
cleanup();
|
|
}
|