Unset and restore authorization extraheader only

This commit is contained in:
Peter Evans 2020-02-22 16:56:39 +09:00
parent ea1eaf1734
commit 0d42c285a3
4 changed files with 74 additions and 36 deletions

38
dist/index.js vendored
View file

@ -4222,6 +4222,7 @@ const {
} = __webpack_require__(718); } = __webpack_require__(718);
const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader"; const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader";
const EXTRAHEADER_VALUE_REGEX = "^AUTHORIZATION:";
async function run() { async function run() {
try { try {
@ -4301,9 +4302,10 @@ async function run() {
// Get the repository path // Get the repository path
var repoPath = getRepoPath(inputs.path); var repoPath = getRepoPath(inputs.path);
// Get the extraheader config option if it exists // Get the extraheader config option if it exists
var extraHeaderOptionValue = await getAndUnsetConfigOption( var extraHeaderOption = await getAndUnsetConfigOption(
repoPath, repoPath,
EXTRAHEADER_OPTION EXTRAHEADER_OPTION,
EXTRAHEADER_VALUE_REGEX
); );
// Execute create pull request // Execute create pull request
@ -4312,12 +4314,12 @@ async function run() {
core.setFailed(error.message); core.setFailed(error.message);
} finally { } finally {
// Restore the extraheader config option // Restore the extraheader config option
if (extraHeaderOptionValue) { if (extraHeaderOption) {
if ( if (
await addConfigOption( await addConfigOption(
repoPath, repoPath,
EXTRAHEADER_OPTION, EXTRAHEADER_OPTION,
extraHeaderOptionValue extraHeaderOption.value
) )
) )
core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`); core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`);
@ -4379,39 +4381,43 @@ async function addConfigOption(repoPath, name, value) {
return result.exitCode === 0; return result.exitCode === 0;
} }
async function unsetConfigOption(repoPath, name) { async function unsetConfigOption(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", "--unset", name], ["config", "--local", "--unset", name, valueRegex],
true true
); );
return result.exitCode === 0; return result.exitCode === 0;
} }
async function configOptionExists(repoPath, name) { async function configOptionExists(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", "--name-only", "--get-regexp", name], ["config", "--local", "--name-only", "--get-regexp", name, valueRegex],
true true
); );
return result.exitCode === 0; return result.exitCode === 0;
} }
async function getConfigOption(repoPath, name) { async function getConfigOption(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", name], ["config", "--local", "--get-regexp", name, valueRegex],
true true
); );
return result.stdout.trim(); const option = result.stdout.trim().split(`${name} `);
return {
name: name,
value: option[1]
}
} }
async function getAndUnsetConfigOption(repoPath, name) { async function getAndUnsetConfigOption(repoPath, name, valueRegex=".") {
if (await configOptionExists(repoPath, name)) { if (await configOptionExists(repoPath, name, valueRegex)) {
const extraHeaderOptionValue = await getConfigOption(repoPath, name); const option = await getConfigOption(repoPath, name, valueRegex);
if (await unsetConfigOption(repoPath, name)) { if (await unsetConfigOption(repoPath, name, valueRegex)) {
core.debug(`Unset config option '${name}'`); core.debug(`Unset config option '${name}'`);
return extraHeaderOptionValue; return option;
} }
} }
return null; return null;

View file

@ -44,39 +44,43 @@ async function addConfigOption(repoPath, name, value) {
return result.exitCode === 0; return result.exitCode === 0;
} }
async function unsetConfigOption(repoPath, name) { async function unsetConfigOption(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", "--unset", name], ["config", "--local", "--unset", name, valueRegex],
true true
); );
return result.exitCode === 0; return result.exitCode === 0;
} }
async function configOptionExists(repoPath, name) { async function configOptionExists(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", "--name-only", "--get-regexp", name], ["config", "--local", "--name-only", "--get-regexp", name, valueRegex],
true true
); );
return result.exitCode === 0; return result.exitCode === 0;
} }
async function getConfigOption(repoPath, name) { async function getConfigOption(repoPath, name, valueRegex=".") {
const result = await execGit( const result = await execGit(
repoPath, repoPath,
["config", "--local", name], ["config", "--local", "--get-regexp", name, valueRegex],
true true
); );
return result.stdout.trim(); const option = result.stdout.trim().split(`${name} `);
return {
name: name,
value: option[1]
}
} }
async function getAndUnsetConfigOption(repoPath, name) { async function getAndUnsetConfigOption(repoPath, name, valueRegex=".") {
if (await configOptionExists(repoPath, name)) { if (await configOptionExists(repoPath, name, valueRegex)) {
const extraHeaderOptionValue = await getConfigOption(repoPath, name); const option = await getConfigOption(repoPath, name, valueRegex);
if (await unsetConfigOption(repoPath, name)) { if (await unsetConfigOption(repoPath, name, valueRegex)) {
core.debug(`Unset config option '${name}'`); core.debug(`Unset config option '${name}'`);
return extraHeaderOptionValue; return option;
} }
} }
return null; return null;

View file

@ -29,12 +29,20 @@ test("execGit", async () => {
test("add and unset config option", async () => { test("add and unset config option", async () => {
const repoPath = getRepoPath(); 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(); expect(add).toBeTruthy();
const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option"); const unset = await unsetConfigOption(repoPath, "test.add.and.unset.config.option");
expect(unset).toBeTruthy(); 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 () => { test("configOptionExists returns true", async () => {
const repoPath = getRepoPath(); const repoPath = getRepoPath();
const result = await configOptionExists(repoPath, "remote.origin.url"); const result = await configOptionExists(repoPath, "remote.origin.url");
@ -51,18 +59,36 @@ test("get config option", async () => {
const repoPath = getRepoPath(); const repoPath = getRepoPath();
const add = await addConfigOption(repoPath, "test.get.config.option", "foo"); const add = await addConfigOption(repoPath, "test.get.config.option", "foo");
expect(add).toBeTruthy(); expect(add).toBeTruthy();
const get = await getConfigOption(repoPath, "test.get.config.option"); const option = await getConfigOption(repoPath, "test.get.config.option");
expect(get).toEqual("foo"); expect(option.value).toEqual("foo");
const unset = await unsetConfigOption(repoPath, "test.get.config.option"); const unset = await unsetConfigOption(repoPath, "test.get.config.option");
expect(unset).toBeTruthy(); 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 () => { test("get and unset config option is successful", async () => {
const repoPath = getRepoPath(); const repoPath = getRepoPath();
const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo"); const add = await addConfigOption(repoPath, "test.get.and.unset.config.option", "foo");
expect(add).toBeTruthy(); expect(add).toBeTruthy();
const getAndUnset = await getAndUnsetConfigOption(repoPath, "test.get.and.unset.config.option"); 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 () => { test("get and unset config option is unsuccessful", async () => {

View file

@ -10,6 +10,7 @@ const {
} = require("./git"); } = require("./git");
const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader"; const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader";
const EXTRAHEADER_VALUE_REGEX = "^AUTHORIZATION:";
async function run() { async function run() {
try { try {
@ -89,9 +90,10 @@ async function run() {
// Get the repository path // Get the repository path
var repoPath = getRepoPath(inputs.path); var repoPath = getRepoPath(inputs.path);
// Get the extraheader config option if it exists // Get the extraheader config option if it exists
var extraHeaderOptionValue = await getAndUnsetConfigOption( var extraHeaderOption = await getAndUnsetConfigOption(
repoPath, repoPath,
EXTRAHEADER_OPTION EXTRAHEADER_OPTION,
EXTRAHEADER_VALUE_REGEX
); );
// Execute create pull request // Execute create pull request
@ -100,12 +102,12 @@ async function run() {
core.setFailed(error.message); core.setFailed(error.message);
} finally { } finally {
// Restore the extraheader config option // Restore the extraheader config option
if (extraHeaderOptionValue) { if (extraHeaderOption) {
if ( if (
await addConfigOption( await addConfigOption(
repoPath, repoPath,
EXTRAHEADER_OPTION, EXTRAHEADER_OPTION,
extraHeaderOptionValue extraHeaderOption.value
) )
) )
core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`); core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`);