From 2d5664ca5a156364e79c48e8ae7516cd18895a4f Mon Sep 17 00:00:00 2001 From: CrazyMax Date: Mon, 4 May 2020 19:17:01 +0200 Subject: [PATCH] Try to solve gpg-preset-passphrase --- dist/index.js | 36 ++++++++++++++++++++++++++---------- src/gpg.ts | 41 ++++++++++++++++++++++++++++++----------- src/main.ts | 2 ++ 3 files changed, 58 insertions(+), 21 deletions(-) diff --git a/dist/index.js b/dist/index.js index 989000f..cb6ab77 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1015,6 +1015,7 @@ const core = __importStar(__webpack_require__(470)); const gpg = __importStar(__webpack_require__(207)); const openpgp = __importStar(__webpack_require__(781)); const stateHelper = __importStar(__webpack_require__(153)); +const exec = __importStar(__webpack_require__(986)); function run() { return __awaiter(this, void 0, void 0, function* () { try { @@ -1023,6 +1024,7 @@ function run() { return; } core.info('📣 GnuPG info'); + yield exec.exec('which', ['gpg']); const version = yield gpg.getVersion(); const dirs = yield gpg.getDirs(); core.info(`Version : ${version.gnupg} (libgcrypt ${version.libgcrypt})`); @@ -1114,6 +1116,24 @@ const exec = __importStar(__webpack_require__(807)); exports.agentConfig = `default-cache-ttl 7200 max-cache-ttl 31536000 allow-preset-passphrase`; +const getGpgPresetPassphrasePath = () => __awaiter(void 0, void 0, void 0, function* () { + const { libexecdir: libexecdir } = yield exports.getDirs(); + let gpgPresetPassphrasePath = path.join(libexecdir, 'gpg-preset-passphrase'); + if (os.platform() == 'win32' && !gpgPresetPassphrasePath.includes(':')) { + gpgPresetPassphrasePath = path.join(process.env.HOMEDRIVE || '', libexecdir, 'gpg-preset-passphrase.exe'); + } + return gpgPresetPassphrasePath; +}); +const getGnupgHome = () => __awaiter(void 0, void 0, void 0, function* () { + if (process.env.GNUPGHOME) { + return process.env.GNUPGHOME; + } + let homedir = path.join(process.env.HOME || '', '.gnupg'); + if (os.platform() == 'win32' && !process.env.HOME) { + homedir = path.join(process.env.USERPROFILE || '', '.gnupg'); + } + return homedir; +}); exports.getVersion = () => __awaiter(void 0, void 0, void 0, function* () { return yield exec.exec('gpg', ['--version'], true).then(res => { if (res.stderr != '') { @@ -1162,10 +1182,10 @@ exports.getDirs = () => __awaiter(void 0, void 0, void 0, function* () { } } return { - libdir: path.normalize(libdir), - libexecdir: path.normalize(libexecdir), - datadir: path.normalize(datadir), - homedir: path.normalize(homedir) + libdir: libdir, + libexecdir: libexecdir, + datadir: datadir, + homedir: homedir }; }); }); @@ -1205,11 +1225,7 @@ exports.getKeygrip = (fingerprint) => __awaiter(void 0, void 0, void 0, function }); }); exports.configureAgent = (config) => __awaiter(void 0, void 0, void 0, function* () { - let homedir = path.join(process.env.HOME || '', '.gnupg'); - if (os.platform() == 'win32') { - homedir = path.join(process.env.USERPROFILE || '', '.gnupg'); - } - const gpgAgentConf = path.join(homedir, 'gpg-agent.conf'); + const gpgAgentConf = path.join(yield getGnupgHome(), 'gpg-agent.conf'); yield fs.writeFile(gpgAgentConf, config, function (err) { if (err) throw err; @@ -1222,7 +1238,7 @@ exports.configureAgent = (config) => __awaiter(void 0, void 0, void 0, function* }); exports.presetPassphrase = (keygrip, passphrase) => __awaiter(void 0, void 0, void 0, function* () { yield exec - .exec('gpg-preset-passphrase', ['--verbose', '--preset', '--passphrase', `"${passphrase}"`, keygrip], true) + .exec(yield getGpgPresetPassphrasePath(), ['--verbose', '--preset', '--passphrase', `"${passphrase}"`, keygrip], true) .then(res => { if (res.stderr != '' && !res.success) { throw new Error(res.stderr); diff --git a/src/gpg.ts b/src/gpg.ts index 5846d6c..27f27c9 100644 --- a/src/gpg.ts +++ b/src/gpg.ts @@ -19,6 +19,26 @@ export interface Dirs { homedir: string; } +const getGpgPresetPassphrasePath = async (): Promise => { + const {libexecdir: libexecdir} = await getDirs(); + let gpgPresetPassphrasePath = path.join(libexecdir, 'gpg-preset-passphrase'); + if (os.platform() == 'win32' && !gpgPresetPassphrasePath.includes(':')) { + gpgPresetPassphrasePath = path.join(process.env.HOMEDRIVE || '', libexecdir, 'gpg-preset-passphrase.exe'); + } + return gpgPresetPassphrasePath; +}; + +const getGnupgHome = async (): Promise => { + if (process.env.GNUPGHOME) { + return process.env.GNUPGHOME; + } + let homedir: string = path.join(process.env.HOME || '', '.gnupg'); + if (os.platform() == 'win32' && !process.env.HOME) { + homedir = path.join(process.env.USERPROFILE || '', '.gnupg'); + } + return homedir; +}; + export const getVersion = async (): Promise => { return await exec.exec('gpg', ['--version'], true).then(res => { if (res.stderr != '') { @@ -69,10 +89,10 @@ export const getDirs = async (): Promise => { } return { - libdir: path.normalize(libdir), - libexecdir: path.normalize(libexecdir), - datadir: path.normalize(datadir), - homedir: path.normalize(homedir) + libdir: libdir, + libexecdir: libexecdir, + datadir: datadir, + homedir: homedir }; }); }; @@ -116,12 +136,7 @@ export const getKeygrip = async (fingerprint: string): Promise => { }; export const configureAgent = async (config: string): Promise => { - let homedir: string = path.join(process.env.HOME || '', '.gnupg'); - if (os.platform() == 'win32') { - homedir = path.join(process.env.USERPROFILE || '', '.gnupg'); - } - - const gpgAgentConf = path.join(homedir, 'gpg-agent.conf'); + const gpgAgentConf = path.join(await getGnupgHome(), 'gpg-agent.conf'); await fs.writeFile(gpgAgentConf, config, function (err) { if (err) throw err; }); @@ -135,7 +150,11 @@ export const configureAgent = async (config: string): Promise => { export const presetPassphrase = async (keygrip: string, passphrase: string): Promise => { await exec - .exec('gpg-preset-passphrase', ['--verbose', '--preset', '--passphrase', `"${passphrase}"`, keygrip], true) + .exec( + await getGpgPresetPassphrasePath(), + ['--verbose', '--preset', '--passphrase', `"${passphrase}"`, keygrip], + true + ) .then(res => { if (res.stderr != '' && !res.success) { throw new Error(res.stderr); diff --git a/src/main.ts b/src/main.ts index e9966b2..ace49c2 100644 --- a/src/main.ts +++ b/src/main.ts @@ -2,6 +2,7 @@ import * as core from '@actions/core'; import * as gpg from './gpg'; import * as openpgp from './openpgp'; import * as stateHelper from './state-helper'; +import * as exec from '@actions/exec'; async function run(): Promise { try { @@ -11,6 +12,7 @@ async function run(): Promise { } core.info('📣 GnuPG info'); + await exec.exec('which', ['gpg']); const version = await gpg.getVersion(); const dirs = await gpg.getDirs(); core.info(`Version : ${version.gnupg} (libgcrypt ${version.libgcrypt})`);