mirror of
https://github.com/crazy-max/ghaction-import-gpg.git
synced 2024-11-25 06:21:03 -05:00
Fix error deleting keys with short key id (#129)
Error: ``` gpg: can't do this in batch mode ``` The GPG command: ``` gpg --batch --yes --delete-secret-keys FINGERPRINT ``` requires to use a fingerprint if you use the `--batch` option. We were using the short ID of the primary key.
This commit is contained in:
parent
87adbd8820
commit
11e26b9f0b
4 changed files with 14 additions and 22 deletions
|
@ -20,6 +20,7 @@ const userInfos = [
|
||||||
name: 'Joe Tester',
|
name: 'Joe Tester',
|
||||||
email: 'joe@foo.bar',
|
email: 'joe@foo.bar',
|
||||||
keyID: '7D851EB72D73BDA0',
|
keyID: '7D851EB72D73BDA0',
|
||||||
|
primary_key_fingerprint: '27571A53B86AF0C799B38BA77D851EB72D73BDA0',
|
||||||
fingerprint: '27571A53B86AF0C799B38BA77D851EB72D73BDA0',
|
fingerprint: '27571A53B86AF0C799B38BA77D851EB72D73BDA0',
|
||||||
fingerprints: ['27571A53B86AF0C799B38BA77D851EB72D73BDA0', '5A282E1460C0BC419615D34DD523BD50DD70B0BA'],
|
fingerprints: ['27571A53B86AF0C799B38BA77D851EB72D73BDA0', '5A282E1460C0BC419615D34DD523BD50DD70B0BA'],
|
||||||
keygrips: ['3E2D1142AA59E08E16B7E2C64BA6DDC773B1A627', 'BA83FC8947213477F28ADC019F6564A956456163']
|
keygrips: ['3E2D1142AA59E08E16B7E2C64BA6DDC773B1A627', 'BA83FC8947213477F28ADC019F6564A956456163']
|
||||||
|
@ -41,6 +42,7 @@ const userInfos = [
|
||||||
name: 'Joe Bar',
|
name: 'Joe Bar',
|
||||||
email: 'joe@bar.foo',
|
email: 'joe@bar.foo',
|
||||||
keyID: '6071D218380FDCC8',
|
keyID: '6071D218380FDCC8',
|
||||||
|
primary_key_fingerprint: '87F257B89CE462100BEC0FFE6071D218380FDCC8',
|
||||||
fingerprint: 'C17D11ADF199F12A30A0910F1F80449BE0B08CB8',
|
fingerprint: 'C17D11ADF199F12A30A0910F1F80449BE0B08CB8',
|
||||||
fingerprints: ['87F257B89CE462100BEC0FFE6071D218380FDCC8', 'C17D11ADF199F12A30A0910F1F80449BE0B08CB8'],
|
fingerprints: ['87F257B89CE462100BEC0FFE6071D218380FDCC8', 'C17D11ADF199F12A30A0910F1F80449BE0B08CB8'],
|
||||||
keygrips: ['F5C3ABFAAB36B427FD98C4EDD0387E08EA1E8092', 'DEE0FC98F441519CA5DE5D79773CB29009695FEB']
|
keygrips: ['F5C3ABFAAB36B427FD98C4EDD0387E08EA1E8092', 'DEE0FC98F441519CA5DE5D79773CB29009695FEB']
|
||||||
|
@ -133,7 +135,7 @@ for (let userInfo of userInfos) {
|
||||||
describe('deleteKey', () => {
|
describe('deleteKey', () => {
|
||||||
it('removes key from GnuPG', async () => {
|
it('removes key from GnuPG', async () => {
|
||||||
await gpg.importKey(userInfo.pgp);
|
await gpg.importKey(userInfo.pgp);
|
||||||
await gpg.deleteKey(userInfo.fingerprint);
|
await gpg.deleteKey(userInfo.primary_key_fingerprint);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
16
dist/index.js
generated
vendored
16
dist/index.js
generated
vendored
|
@ -439,12 +439,11 @@ function run() {
|
||||||
core.info(`Email : ${privateKey.email}`);
|
core.info(`Email : ${privateKey.email}`);
|
||||||
core.info(`CreationTime : ${privateKey.creationTime}`);
|
core.info(`CreationTime : ${privateKey.creationTime}`);
|
||||||
}));
|
}));
|
||||||
|
stateHelper.setFingerprint(privateKey.fingerprint);
|
||||||
let fingerprint = privateKey.fingerprint;
|
let fingerprint = privateKey.fingerprint;
|
||||||
if (inputs.fingerprint) {
|
if (inputs.fingerprint) {
|
||||||
fingerprint = inputs.fingerprint;
|
fingerprint = inputs.fingerprint;
|
||||||
}
|
}
|
||||||
stateHelper.setFingerprint(fingerprint);
|
|
||||||
stateHelper.setKeyID(privateKey.keyID);
|
|
||||||
yield core.group(`Fingerprint to use`, () => __awaiter(this, void 0, void 0, function* () {
|
yield core.group(`Fingerprint to use`, () => __awaiter(this, void 0, void 0, function* () {
|
||||||
core.info(fingerprint);
|
core.info(fingerprint);
|
||||||
}));
|
}));
|
||||||
|
@ -522,12 +521,12 @@ function run() {
|
||||||
function cleanup() {
|
function cleanup() {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
if (stateHelper.fingerprint.length <= 0) {
|
if (stateHelper.fingerprint.length <= 0) {
|
||||||
core.debug('Fingerprint is not defined. Skipping cleanup.');
|
core.debug('Primary key fingerprint is not defined. Skipping cleanup.');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
core.info('Removing keys');
|
core.info(`Removing key ${stateHelper.fingerprint}`);
|
||||||
yield gpg.deleteKey(stateHelper.keyId);
|
yield gpg.deleteKey(stateHelper.fingerprint);
|
||||||
core.info('Killing GnuPG agent');
|
core.info('Killing GnuPG agent');
|
||||||
yield gpg.killAgent();
|
yield gpg.killAgent();
|
||||||
}
|
}
|
||||||
|
@ -645,19 +644,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||||
exports.setKeyID = exports.setFingerprint = exports.keyId = exports.fingerprint = exports.IsPost = void 0;
|
exports.setFingerprint = exports.fingerprint = exports.IsPost = void 0;
|
||||||
const core = __importStar(__webpack_require__(2186));
|
const core = __importStar(__webpack_require__(2186));
|
||||||
exports.IsPost = !!process.env['STATE_isPost'];
|
exports.IsPost = !!process.env['STATE_isPost'];
|
||||||
exports.fingerprint = process.env['STATE_fingerprint'] || '';
|
exports.fingerprint = process.env['STATE_fingerprint'] || '';
|
||||||
exports.keyId = process.env['STATE_keyId'] || '';
|
|
||||||
function setFingerprint(fingerprint) {
|
function setFingerprint(fingerprint) {
|
||||||
core.saveState('fingerprint', fingerprint);
|
core.saveState('fingerprint', fingerprint);
|
||||||
}
|
}
|
||||||
exports.setFingerprint = setFingerprint;
|
exports.setFingerprint = setFingerprint;
|
||||||
function setKeyID(keyID) {
|
|
||||||
core.saveState('keyId', keyID);
|
|
||||||
}
|
|
||||||
exports.setKeyID = setKeyID;
|
|
||||||
if (!exports.IsPost) {
|
if (!exports.IsPost) {
|
||||||
core.saveState('isPost', 'true');
|
core.saveState('isPost', 'true');
|
||||||
}
|
}
|
||||||
|
|
11
src/main.ts
11
src/main.ts
|
@ -33,12 +33,13 @@ async function run(): Promise<void> {
|
||||||
core.info(`CreationTime : ${privateKey.creationTime}`);
|
core.info(`CreationTime : ${privateKey.creationTime}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
stateHelper.setFingerprint(privateKey.fingerprint);
|
||||||
|
|
||||||
let fingerprint = privateKey.fingerprint;
|
let fingerprint = privateKey.fingerprint;
|
||||||
if (inputs.fingerprint) {
|
if (inputs.fingerprint) {
|
||||||
fingerprint = inputs.fingerprint;
|
fingerprint = inputs.fingerprint;
|
||||||
}
|
}
|
||||||
stateHelper.setFingerprint(fingerprint);
|
|
||||||
stateHelper.setKeyID(privateKey.keyID);
|
|
||||||
await core.group(`Fingerprint to use`, async () => {
|
await core.group(`Fingerprint to use`, async () => {
|
||||||
core.info(fingerprint);
|
core.info(fingerprint);
|
||||||
});
|
});
|
||||||
|
@ -127,12 +128,12 @@ async function run(): Promise<void> {
|
||||||
|
|
||||||
async function cleanup(): Promise<void> {
|
async function cleanup(): Promise<void> {
|
||||||
if (stateHelper.fingerprint.length <= 0) {
|
if (stateHelper.fingerprint.length <= 0) {
|
||||||
core.debug('Fingerprint is not defined. Skipping cleanup.');
|
core.debug('Primary key fingerprint is not defined. Skipping cleanup.');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
core.info('Removing keys');
|
core.info(`Removing key ${stateHelper.fingerprint}`);
|
||||||
await gpg.deleteKey(stateHelper.keyId);
|
await gpg.deleteKey(stateHelper.fingerprint);
|
||||||
|
|
||||||
core.info('Killing GnuPG agent');
|
core.info('Killing GnuPG agent');
|
||||||
await gpg.killAgent();
|
await gpg.killAgent();
|
||||||
|
|
|
@ -2,16 +2,11 @@ import * as core from '@actions/core';
|
||||||
|
|
||||||
export const IsPost = !!process.env['STATE_isPost'];
|
export const IsPost = !!process.env['STATE_isPost'];
|
||||||
export const fingerprint = process.env['STATE_fingerprint'] || '';
|
export const fingerprint = process.env['STATE_fingerprint'] || '';
|
||||||
export const keyId = process.env['STATE_keyId'] || '';
|
|
||||||
|
|
||||||
export function setFingerprint(fingerprint: string) {
|
export function setFingerprint(fingerprint: string) {
|
||||||
core.saveState('fingerprint', fingerprint);
|
core.saveState('fingerprint', fingerprint);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function setKeyID(keyID: string) {
|
|
||||||
core.saveState('keyId', keyID);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!IsPost) {
|
if (!IsPost) {
|
||||||
core.saveState('isPost', 'true');
|
core.saveState('isPost', 'true');
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue