From 1e09ec2f22ed5ccac35a4159ac4b3d1d0b0bfa31 Mon Sep 17 00:00:00 2001 From: Peter Evans Date: Fri, 10 Jan 2020 00:11:39 +0900 Subject: [PATCH] Add path input --- README.md | 10 ++++++---- action.yml | 4 +++- dist/index.js | 2 ++ dist/src/create_pull_request.py | 5 +++-- index.js | 2 ++ src/create_pull_request.py | 5 +++-- 6 files changed, 19 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 4682561..e13aacd 100644 --- a/README.md +++ b/README.md @@ -33,15 +33,17 @@ Create Pull Request action will: You can also pin to a [specific release](https://github.com/peter-evans/create-pull-request/releases) version in the format `@v2.x.x` +### Action inputs + +With the exception of `token`, all inputs are **optional**. If not set, sensible default values will be used. + **Note**: If you want pull requests created by this action to trigger an `on: pull_request` workflow then you must use a [Personal Access Token](https://help.github.com/en/articles/creating-a-personal-access-token-for-the-command-line) instead of the default `GITHUB_TOKEN`. See [this issue](https://github.com/peter-evans/create-pull-request/issues/48) for further details. -### Action inputs - -These inputs are *all optional*. If not set, sensible default values will be used. - | Name | Description | Default | | --- | --- | --- | +| `token` | `GITHUB_TOKEN` or a `repo` scoped [PAT](https://help.github.com/en/github/authenticating-to-github/creating-a-personal-access-token-for-the-command-line). | | +| `path` | Relative path under `$GITHUB_WORKSPACE` to the repository. | `$GITHUB_WORKSPACE` | | `commit-message` | The message to use when committing changes. | `[create-pull-request] automated change` | | `committer` | The committer name and email address in the format `Display Name `. | Defaults to the GitHub Actions bot user. See [Committer and author](#committer-and-author) for details. | | `author` | The author name and email address in the format `Display Name `. | Defaults to the GitHub Actions bot user. See [Committer and author](#committer-and-author) for details. | diff --git a/action.yml b/action.yml index 647cef3..00f233d 100644 --- a/action.yml +++ b/action.yml @@ -2,8 +2,10 @@ name: 'Create Pull Request' description: 'Creates a pull request for changes to your repository in the actions workspace' inputs: token: - description: 'The GitHub authentication token' + description: 'GITHUB_TOKEN or a repo scoped PAT' required: true + path: + description: 'Relative path under $GITHUB_WORKSPACE to the repository.' commit-message: description: 'The message to use when committing changes.' committer: diff --git a/dist/index.js b/dist/index.js index 1890c82..a977658 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1024,6 +1024,7 @@ async function run() { // Fetch action inputs const inputs = { token: core.getInput("token"), + path: core.getInput("path"), commitMessage: core.getInput("commit-message"), committer: core.getInput("committer"), author: core.getInput("author"), @@ -1044,6 +1045,7 @@ async function run() { // Set environment variables from inputs. if (inputs.token) process.env.GITHUB_TOKEN = inputs.token; + if (inputs.path) process.env.CPR_PATH = inputs.path; 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; diff --git a/dist/src/create_pull_request.py b/dist/src/create_pull_request.py index 3578da0..8a83a7e 100755 --- a/dist/src/create_pull_request.py +++ b/dist/src/create_pull_request.py @@ -96,6 +96,7 @@ def set_committer_author(repo, committer, author): github_token = os.environ["GITHUB_TOKEN"] github_repository = os.environ["GITHUB_REPOSITORY"] # Get environment variables with defaults +path = os.getenv("CPR_PATH", os.getcwd()) branch = os.getenv("CPR_BRANCH", DEFAULT_BRANCH) commit_message = os.getenv("CPR_COMMIT_MESSAGE", DEFAULT_COMMIT_MESSAGE) # Get environment variables with a default of 'None' @@ -103,8 +104,8 @@ committer = os.environ.get("CPR_COMMITTER") author = os.environ.get("CPR_AUTHOR") base = os.environ.get("CPR_BASE") -# Set the repo to the working directory -repo = Repo(os.getcwd()) +# Set the repo path +repo = Repo(path) # Determine if the checked out ref is a valid base for a pull request # The action needs the checked out HEAD ref to be a branch diff --git a/index.js b/index.js index d27b62b..9df859c 100644 --- a/index.js +++ b/index.js @@ -22,6 +22,7 @@ async function run() { // Fetch action inputs const inputs = { token: core.getInput("token"), + path: core.getInput("path"), commitMessage: core.getInput("commit-message"), committer: core.getInput("committer"), author: core.getInput("author"), @@ -42,6 +43,7 @@ async function run() { // Set environment variables from inputs. if (inputs.token) process.env.GITHUB_TOKEN = inputs.token; + if (inputs.path) process.env.CPR_PATH = inputs.path; 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; diff --git a/src/create_pull_request.py b/src/create_pull_request.py index 3578da0..8a83a7e 100755 --- a/src/create_pull_request.py +++ b/src/create_pull_request.py @@ -96,6 +96,7 @@ def set_committer_author(repo, committer, author): github_token = os.environ["GITHUB_TOKEN"] github_repository = os.environ["GITHUB_REPOSITORY"] # Get environment variables with defaults +path = os.getenv("CPR_PATH", os.getcwd()) branch = os.getenv("CPR_BRANCH", DEFAULT_BRANCH) commit_message = os.getenv("CPR_COMMIT_MESSAGE", DEFAULT_COMMIT_MESSAGE) # Get environment variables with a default of 'None' @@ -103,8 +104,8 @@ committer = os.environ.get("CPR_COMMITTER") author = os.environ.get("CPR_AUTHOR") base = os.environ.get("CPR_BASE") -# Set the repo to the working directory -repo = Repo(os.getcwd()) +# Set the repo path +repo = Repo(path) # Determine if the checked out ref is a valid base for a pull request # The action needs the checked out HEAD ref to be a branch