mirror of
https://github.com/peter-evans/create-or-update-comment.git
synced 2025-01-19 11:46:40 +08:00
56603d7af0
Co-authored-by: Peter Evans <18365890+peter-evans@users.noreply.github.com>
165 lines
6.9 KiB
Markdown
165 lines
6.9 KiB
Markdown
# Create or Update Comment
|
|
[![CI](https://github.com/peter-evans/create-or-update-comment/workflows/CI/badge.svg)](https://github.com/peter-evans/create-or-update-comment/actions?query=workflow%3ACI)
|
|
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-Create%20or%20Update%20Comment-blue.svg?colorA=24292e&colorB=0366d6&style=flat&longCache=true&logo=)](https://github.com/marketplace/actions/create-or-update-comment)
|
|
|
|
A GitHub action to create or update an issue or pull request comment.
|
|
|
|
This action was created to help facilitate a GitHub Actions "ChatOps" solution in conjunction with [slash-command-dispatch](https://github.com/peter-evans/slash-command-dispatch) action.
|
|
|
|
## Usage
|
|
|
|
### Add a comment to an issue or pull request
|
|
|
|
```yml
|
|
- name: Create comment
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
issue-number: 1
|
|
body: |
|
|
This is a multi-line test comment
|
|
- With GitHub **Markdown** :sparkles:
|
|
- Created by [create-or-update-comment][1]
|
|
|
|
[1]: https://github.com/peter-evans/create-or-update-comment
|
|
reactions: '+1'
|
|
```
|
|
|
|
### Update a comment
|
|
|
|
```yml
|
|
- name: Update comment
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
comment-id: 557858210
|
|
body: |
|
|
**Edit:** Some additional info
|
|
reactions: eyes
|
|
```
|
|
|
|
### Add comment reactions
|
|
|
|
```yml
|
|
- name: Add reactions
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
comment-id: 557858210
|
|
reactions: heart, hooray, laugh
|
|
```
|
|
|
|
### Action inputs
|
|
|
|
| Name | Description | Default |
|
|
| --- | --- | --- |
|
|
| `token` | `GITHUB_TOKEN` or a `repo` scoped [PAT](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token). | `GITHUB_TOKEN` |
|
|
| `repository` | The full name of the repository in which to create or update a comment. | Current repository |
|
|
| `issue-number` | The number of the issue or pull request in which to create a comment. | |
|
|
| `comment-id` | The id of the comment to update. | |
|
|
| `body` | The comment body. | |
|
|
| `edit-mode` | The mode when updating a comment, `replace` or `append`. | `append` |
|
|
| `reactions` | A comma separated list of reactions to add to the comment. (`+1`, `-1`, `laugh`, `confused`, `heart`, `hooray`, `rocket`, `eyes`) | |
|
|
|
|
Note: In *public* repositories this action does not work in `pull_request` workflows when triggered by forks.
|
|
This is due to token restrictions put in place by GitHub Actions. Private repositories can be configured to [enable workflows](https://docs.github.com/en/github/administering-a-repository/disabling-or-limiting-github-actions-for-a-repository#enabling-workflows-for-private-repository-forks) from forks to run without restriction. See [here](https://github.com/peter-evans/create-pull-request/blob/master/docs/concepts-guidelines.md#restrictions-on-repository-forks) for further explanation. Alternatively, use the [`pull_request_target`](https://docs.github.com/en/actions/reference/events-that-trigger-workflows#pull_request_target) event to comment on pull requests.
|
|
|
|
#### Outputs
|
|
|
|
The ID of the created comment will be output for use in later steps.
|
|
Note that in order to read the step output the action step must have an id.
|
|
|
|
```yml
|
|
- name: Create comment
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
id: couc
|
|
with:
|
|
issue-number: 1
|
|
body: |
|
|
My comment
|
|
- name: Check outputs
|
|
run: |
|
|
echo "Comment ID - ${{ steps.couc.outputs.comment-id }}"
|
|
```
|
|
|
|
### Where to find the id of a comment
|
|
|
|
How to find the id of a comment will depend a lot on the use case.
|
|
Here is one example where the id can be found in the `github` context during an `issue_comment` event.
|
|
|
|
```yml
|
|
on:
|
|
issue_comment:
|
|
types: [created]
|
|
jobs:
|
|
commentCreated:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Add reaction
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
comment-id: ${{ github.event.comment.id }}
|
|
reactions: eyes
|
|
```
|
|
|
|
Some use cases might find the [find-comment](https://github.com/peter-evans/find-comment) action useful.
|
|
This will search an issue or pull request for the first comment containing a specified string, and/or by a specified author.
|
|
See the repository for detailed usage.
|
|
|
|
In the following example, find-comment is used to determine a comment has already been created on a pull request. In this case, the comment will be updated instead of being created.
|
|
```yml
|
|
- name: Find Comment
|
|
uses: peter-evans/find-comment@v1
|
|
id: fc
|
|
with:
|
|
issue-number: ${{ github.event.pull_request.number }} #e.g. 1
|
|
comment-author: 'github-actions[bot]'
|
|
body-includes: This comment was written by a bot!
|
|
|
|
- name: Create comment
|
|
if: ${{ steps.fc.outputs.comment-id == 0 }}
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
issue-number: ${{ github.event.pull_request.number }}
|
|
body: |
|
|
This comment was written by a bot!
|
|
reaction-type: "rocket"
|
|
|
|
- name: Update comment
|
|
if: ${{ steps.fc.outputs.comment-id != 0 }}
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
comment-id: ${{ steps.fc.outputs.comment-id }}
|
|
body: |
|
|
Update!
|
|
Comments can also be updated by us. :)
|
|
reaction-type: "rocket"
|
|
```
|
|
|
|
### Setting the comment body from a file
|
|
|
|
This example shows how file content can be read into a variable and passed to the action.
|
|
The content must be [escaped to preserve newlines](https://github.community/t/set-output-truncates-multiline-strings/16852/3).
|
|
|
|
```yml
|
|
- id: get-comment-body
|
|
run: |
|
|
body=$(cat comment-body.txt)
|
|
body="${body//'%'/'%25'}"
|
|
body="${body//$'\n'/'%0A'}"
|
|
body="${body//$'\r'/'%0D'}"
|
|
echo ::set-output name=body::$body
|
|
|
|
- name: Create comment
|
|
uses: peter-evans/create-or-update-comment@v1
|
|
with:
|
|
issue-number: 1
|
|
body: ${{ steps.get-comment-body.outputs.body }}
|
|
```
|
|
|
|
### Accessing issues and comments in other repositories
|
|
|
|
You can create and update comments in another repository by using a [PAT](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token) instead of `GITHUB_TOKEN`.
|
|
The user associated with the PAT must have write access to the repository.
|
|
|
|
## License
|
|
|
|
[MIT](LICENSE)
|