Unset and restore authorization extraheader only
This commit is contained in:
parent
ea1eaf1734
commit
0d42c285a3
4 changed files with 74 additions and 36 deletions
38
dist/index.js
vendored
38
dist/index.js
vendored
|
@ -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;
|
||||||
|
|
28
src/git.js
28
src/git.js
|
@ -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;
|
||||||
|
|
|
@ -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 () => {
|
||||||
|
|
10
src/index.js
10
src/index.js
|
@ -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}'`);
|
||||||
|
|
Loading…
Reference in a new issue