2019-11-09 09:24:47 +01:00
|
|
|
const { inspect } = require("util");
|
2020-02-13 09:36:57 +01:00
|
|
|
const isDocker = require("is-docker");
|
2019-11-09 09:24:47 +01:00
|
|
|
const core = require("@actions/core");
|
|
|
|
const exec = require("@actions/exec");
|
2020-02-22 06:08:54 +01:00
|
|
|
const setupPython = require("./setup-python");
|
|
|
|
const {
|
|
|
|
getRepoPath,
|
|
|
|
getAndUnsetConfigOption,
|
|
|
|
addConfigOption
|
|
|
|
} = require("./git");
|
|
|
|
|
|
|
|
const EXTRAHEADER_OPTION = "http.https://github.com/.extraheader";
|
2020-02-22 08:56:39 +01:00
|
|
|
const EXTRAHEADER_VALUE_REGEX = "^AUTHORIZATION:";
|
2019-11-09 09:24:47 +01:00
|
|
|
|
|
|
|
async function run() {
|
|
|
|
try {
|
|
|
|
// Allows ncc to find assets to be included in the distribution
|
2020-02-22 06:08:54 +01:00
|
|
|
const cpr = __dirname + "/cpr";
|
|
|
|
core.debug(`cpr: ${cpr}`);
|
2019-11-09 09:24:47 +01:00
|
|
|
|
2020-02-13 09:36:57 +01:00
|
|
|
// Determine how to access python and pip
|
|
|
|
const { pip, python } = (function() {
|
|
|
|
if (isDocker()) {
|
|
|
|
core.info("Running inside a Docker container");
|
|
|
|
// Python 3 assumed to be installed and on the PATH
|
|
|
|
return {
|
|
|
|
pip: "pip3",
|
|
|
|
python: "python3"
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
// Setup Python from the tool cache
|
|
|
|
setupPython("3.x", "x64");
|
|
|
|
return {
|
|
|
|
pip: "pip",
|
|
|
|
python: "python"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
})();
|
2019-11-09 09:24:47 +01:00
|
|
|
|
|
|
|
// Install requirements
|
2020-02-13 09:36:57 +01:00
|
|
|
await exec.exec(pip, [
|
2019-11-09 09:24:47 +01:00
|
|
|
"install",
|
|
|
|
"--requirement",
|
2020-02-22 06:08:54 +01:00
|
|
|
`${cpr}/requirements.txt`,
|
2020-01-23 08:59:17 +01:00
|
|
|
"--no-index",
|
|
|
|
`--find-links=${__dirname}/vendor`
|
2019-11-09 09:24:47 +01:00
|
|
|
]);
|
|
|
|
|
|
|
|
// Fetch action inputs
|
|
|
|
const inputs = {
|
|
|
|
token: core.getInput("token"),
|
2020-01-09 16:11:39 +01:00
|
|
|
path: core.getInput("path"),
|
2019-11-09 09:24:47 +01:00
|
|
|
commitMessage: core.getInput("commit-message"),
|
2019-12-27 06:40:08 +01:00
|
|
|
committer: core.getInput("committer"),
|
|
|
|
author: core.getInput("author"),
|
2019-11-09 09:24:47 +01:00
|
|
|
title: core.getInput("title"),
|
|
|
|
body: core.getInput("body"),
|
|
|
|
labels: core.getInput("labels"),
|
|
|
|
assignees: core.getInput("assignees"),
|
|
|
|
reviewers: core.getInput("reviewers"),
|
|
|
|
teamReviewers: core.getInput("team-reviewers"),
|
|
|
|
milestone: core.getInput("milestone"),
|
2019-11-24 00:48:32 +01:00
|
|
|
project: core.getInput("project"),
|
|
|
|
projectColumn: core.getInput("project-column"),
|
2020-04-04 02:47:11 +02:00
|
|
|
draft: core.getInput("draft"),
|
2019-11-09 09:24:47 +01:00
|
|
|
branch: core.getInput("branch"),
|
2020-05-10 10:58:21 +02:00
|
|
|
requestToParent: core.getInput("request-to-parent"),
|
2019-11-09 09:24:47 +01:00
|
|
|
base: core.getInput("base"),
|
2020-02-13 09:36:57 +01:00
|
|
|
branchSuffix: core.getInput("branch-suffix")
|
2019-11-09 09:24:47 +01:00
|
|
|
};
|
|
|
|
core.debug(`Inputs: ${inspect(inputs)}`);
|
|
|
|
|
|
|
|
// Set environment variables from inputs.
|
|
|
|
if (inputs.token) process.env.GITHUB_TOKEN = inputs.token;
|
2020-01-09 16:11:39 +01:00
|
|
|
if (inputs.path) process.env.CPR_PATH = inputs.path;
|
2019-12-27 06:40:08 +01:00
|
|
|
if (inputs.commitMessage) process.env.CPR_COMMIT_MESSAGE = inputs.commitMessage;
|
|
|
|
if (inputs.committer) process.env.CPR_COMMITTER = inputs.committer;
|
|
|
|
if (inputs.author) process.env.CPR_AUTHOR = inputs.author;
|
|
|
|
if (inputs.title) process.env.CPR_TITLE = inputs.title;
|
|
|
|
if (inputs.body) process.env.CPR_BODY = inputs.body;
|
|
|
|
if (inputs.labels) process.env.CPR_LABELS = inputs.labels;
|
|
|
|
if (inputs.assignees) process.env.CPR_ASSIGNEES = inputs.assignees;
|
|
|
|
if (inputs.reviewers) process.env.CPR_REVIEWERS = inputs.reviewers;
|
|
|
|
if (inputs.teamReviewers) process.env.CPR_TEAM_REVIEWERS = inputs.teamReviewers;
|
|
|
|
if (inputs.milestone) process.env.CPR_MILESTONE = inputs.milestone;
|
|
|
|
if (inputs.project) process.env.CPR_PROJECT_NAME = inputs.project;
|
|
|
|
if (inputs.projectColumn) process.env.CPR_PROJECT_COLUMN_NAME = inputs.projectColumn;
|
2020-04-04 02:47:11 +02:00
|
|
|
if (inputs.draft) process.env.CPR_DRAFT = inputs.draft;
|
2019-12-27 06:40:08 +01:00
|
|
|
if (inputs.branch) process.env.CPR_BRANCH = inputs.branch;
|
2020-05-10 10:58:21 +02:00
|
|
|
if (inputs.requestToParent) process.env.CPR_REQUEST_TO_PARENT = inputs.requestToParent;
|
2019-12-27 06:40:08 +01:00
|
|
|
if (inputs.base) process.env.CPR_BASE = inputs.base;
|
|
|
|
if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix;
|
2019-11-09 09:24:47 +01:00
|
|
|
|
2020-02-22 06:08:54 +01:00
|
|
|
// Get the repository path
|
|
|
|
var repoPath = getRepoPath(inputs.path);
|
|
|
|
// Get the extraheader config option if it exists
|
2020-02-22 08:56:39 +01:00
|
|
|
var extraHeaderOption = await getAndUnsetConfigOption(
|
2020-02-22 06:08:54 +01:00
|
|
|
repoPath,
|
2020-02-22 08:56:39 +01:00
|
|
|
EXTRAHEADER_OPTION,
|
|
|
|
EXTRAHEADER_VALUE_REGEX
|
2020-02-22 06:08:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// Execute create pull request
|
|
|
|
await exec.exec(python, [`${cpr}/create_pull_request.py`]);
|
2019-11-09 09:24:47 +01:00
|
|
|
} catch (error) {
|
|
|
|
core.setFailed(error.message);
|
2020-02-22 06:08:54 +01:00
|
|
|
} finally {
|
|
|
|
// Restore the extraheader config option
|
2020-02-22 08:56:39 +01:00
|
|
|
if (extraHeaderOption) {
|
2020-02-22 06:08:54 +01:00
|
|
|
if (
|
|
|
|
await addConfigOption(
|
|
|
|
repoPath,
|
|
|
|
EXTRAHEADER_OPTION,
|
2020-02-22 08:56:39 +01:00
|
|
|
extraHeaderOption.value
|
2020-02-22 06:08:54 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`);
|
|
|
|
}
|
2019-11-09 09:24:47 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
run();
|