diff --git a/dist/index.js b/dist/index.js index 0ccf519..32b5948 100644 --- a/dist/index.js +++ b/dist/index.js @@ -4222,6 +4222,7 @@ const { } = __webpack_require__(718); const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader"; +const EXTRAHEADER_VALUE_REGEX = "^AUTHORIZATION:"; async function run() { try { @@ -4301,9 +4302,10 @@ async function run() { // Get the repository path var repoPath = getRepoPath(inputs.path); // Get the extraheader config option if it exists - var extraHeaderOptionValue = await getAndUnsetConfigOption( + var extraHeaderOption = await getAndUnsetConfigOption( repoPath, - EXTRAHEADER_OPTION + EXTRAHEADER_OPTION, + EXTRAHEADER_VALUE_REGEX ); // Execute create pull request @@ -4312,12 +4314,12 @@ async function run() { core.setFailed(error.message); } finally { // Restore the extraheader config option - if (extraHeaderOptionValue) { + if (extraHeaderOption) { if ( await addConfigOption( repoPath, EXTRAHEADER_OPTION, - extraHeaderOptionValue + extraHeaderOption.value ) ) core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`); @@ -4379,39 +4381,43 @@ async function addConfigOption(repoPath, name, value) { return result.exitCode === 0; } -async function unsetConfigOption(repoPath, name) { +async function unsetConfigOption(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", "--unset", name], + ["config", "--local", "--unset", name, valueRegex], true ); return result.exitCode === 0; } -async function configOptionExists(repoPath, name) { +async function configOptionExists(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", "--name-only", "--get-regexp", name], + ["config", "--local", "--name-only", "--get-regexp", name, valueRegex], true ); return result.exitCode === 0; } -async function getConfigOption(repoPath, name) { +async function getConfigOption(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", name], + ["config", "--local", "--get-regexp", name, valueRegex], true ); - return result.stdout.trim(); + const option = result.stdout.trim().split(`${name} `); + return { + name: name, + value: option[1] + } } -async function getAndUnsetConfigOption(repoPath, name) { - if (await configOptionExists(repoPath, name)) { - const extraHeaderOptionValue = await getConfigOption(repoPath, name); - if (await unsetConfigOption(repoPath, name)) { +async function getAndUnsetConfigOption(repoPath, name, valueRegex=".") { + if (await configOptionExists(repoPath, name, valueRegex)) { + const option = await getConfigOption(repoPath, name, valueRegex); + if (await unsetConfigOption(repoPath, name, valueRegex)) { core.debug(`Unset config option '${name}'`); - return extraHeaderOptionValue; + return option; } } return null; diff --git a/src/git.js b/src/git.js index 92f3fc0..604f67b 100644 --- a/src/git.js +++ b/src/git.js @@ -44,39 +44,43 @@ async function addConfigOption(repoPath, name, value) { return result.exitCode === 0; } -async function unsetConfigOption(repoPath, name) { +async function unsetConfigOption(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", "--unset", name], + ["config", "--local", "--unset", name, valueRegex], true ); return result.exitCode === 0; } -async function configOptionExists(repoPath, name) { +async function configOptionExists(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", "--name-only", "--get-regexp", name], + ["config", "--local", "--name-only", "--get-regexp", name, valueRegex], true ); return result.exitCode === 0; } -async function getConfigOption(repoPath, name) { +async function getConfigOption(repoPath, name, valueRegex=".") { const result = await execGit( repoPath, - ["config", "--local", name], + ["config", "--local", "--get-regexp", name, valueRegex], true ); - return result.stdout.trim(); + const option = result.stdout.trim().split(`${name} `); + return { + name: name, + value: option[1] + } } -async function getAndUnsetConfigOption(repoPath, name) { - if (await configOptionExists(repoPath, name)) { - const extraHeaderOptionValue = await getConfigOption(repoPath, name); - if (await unsetConfigOption(repoPath, name)) { +async function getAndUnsetConfigOption(repoPath, name, valueRegex=".") { + if (await configOptionExists(repoPath, name, valueRegex)) { + const option = await getConfigOption(repoPath, name, valueRegex); + if (await unsetConfigOption(repoPath, name, valueRegex)) { core.debug(`Unset config option '${name}'`); - return extraHeaderOptionValue; + return option; } } return null; diff --git a/src/git.test.js b/src/git.test.js index 8f247ce..e1361d2 100644 --- a/src/git.test.js +++ b/src/git.test.js @@ -29,12 +29,20 @@ test("execGit", async () => { test("add and unset config option", async () => { const repoPath = getRepoPath(); - const add = await addConfigOption(repoPath, "test.add.and.unset.config.option", "true"); + const add = await addConfigOption(repoPath, "test.add.and.unset.config.option", "foo"); expect(add).toBeTruthy(); const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option"); expect(unset).toBeTruthy(); }); +test("add and unset config option with value regex", async () => { + const repoPath = getRepoPath(); + const add = await addConfigOption(repoPath, "test.add.and.unset.config.option", "foo bar"); + expect(add).toBeTruthy(); + const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option", "^foo"); + expect(unset).toBeTruthy(); +}); + test("configOptionExists returns true", async () => { const repoPath = getRepoPath(); const result = await configOptionExists(repoPath, "remote.origin.url"); @@ -51,18 +59,36 @@ test("get config option", async () => { const repoPath = getRepoPath(); const add = await addConfigOption(repoPath, "test.get.config.option", "foo"); expect(add).toBeTruthy(); - const get = await getConfigOption(repoPath, "test.get.config.option"); - expect(get).toEqual("foo"); + const option = await getConfigOption(repoPath, "test.get.config.option"); + expect(option.value).toEqual("foo"); const unset = await unsetConfigOption(repoPath, "test.get.config.option"); expect(unset).toBeTruthy(); }); +test("get config option with value regex", async () => { + const repoPath = getRepoPath(); + const add = await addConfigOption(repoPath, "test.get.config.option", "foo bar"); + expect(add).toBeTruthy(); + const option = await getConfigOption(repoPath, "test.get.config.option", "^foo"); + expect(option.value).toEqual("foo bar"); + const unset = await unsetConfigOption(repoPath, "test.get.config.option", "^foo"); + expect(unset).toBeTruthy(); +}); + test("get and unset config option is successful", async () => { const repoPath = getRepoPath(); const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo"); expect(add).toBeTruthy(); const getAndUnset = await getAndUnsetConfigOption(repoPath, "test.get.and.unset.config.option"); - expect(getAndUnset).toEqual("foo"); + expect(getAndUnset.value).toEqual("foo"); +}); + +test("get and unset config option is successful with value regex", async () => { + const repoPath = getRepoPath(); + const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo bar"); + expect(add).toBeTruthy(); + const getAndUnset = await getAndUnsetConfigOption(repoPath, "test.get.and.unset.config.option", "^foo"); + expect(getAndUnset.value).toEqual("foo bar"); }); test("get and unset config option is unsuccessful", async () => { diff --git a/src/index.js b/src/index.js index f424602..c82fe82 100644 --- a/src/index.js +++ b/src/index.js @@ -10,6 +10,7 @@ const { } = require("./git"); const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader"; +const EXTRAHEADER_VALUE_REGEX = "^AUTHORIZATION:"; async function run() { try { @@ -89,9 +90,10 @@ async function run() { // Get the repository path var repoPath = getRepoPath(inputs.path); // Get the extraheader config option if it exists - var extraHeaderOptionValue = await getAndUnsetConfigOption( + var extraHeaderOption = await getAndUnsetConfigOption( repoPath, - EXTRAHEADER_OPTION + EXTRAHEADER_OPTION, + EXTRAHEADER_VALUE_REGEX ); // Execute create pull request @@ -100,12 +102,12 @@ async function run() { core.setFailed(error.message); } finally { // Restore the extraheader config option - if (extraHeaderOptionValue) { + if (extraHeaderOption) { if ( await addConfigOption( repoPath, EXTRAHEADER_OPTION, - extraHeaderOptionValue + extraHeaderOption.value ) ) core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`);