This GitHub Action will trigger notifications by creating or commenting on an issue. By default, the action will create a new issue the first time it needs to notify a particular user. It will immediately close this issue so that it doesn't clutter the issues view. For subsequent notifications for that same user, this action will create a new comment on the existing issue.
In order to find the appropriate issue to add a comment to, this action will search for issues that mention the user receiving this notification and an issue that has a title that matches the title for this message. In other words, if you're customizing the title, be sure that the title isn't always changing (e.g., by including the commit or date) because that will ensure that this action will create a new issue everytime. Issue notifications follow regular GitHub rules:
-
All watchers of the repo will be notified of the issue creation.
-
Anyone can unsubscribe from a particular issue.
-
If you are @ mentioned on an issue, you're automatically subscribed to it even if you previously unsubscribed from it.
Default GitHub Action notifications aren't flexible. Other solutions involve secondary services (email API gateway or Slack), which aren't always needed. Additionally, they require a manual mapping from GitHub users to the appropriate email address or Slack user when notifying individual actors. Broadcasting to everyone via an alias or Slack channel can be a nuisance and / or uneccessarily shaming.
This sidesteps those issues for notifying individuals using GitHub itself and assuming that the user will receive an notification somehow (e.g., email) when they are @ mentioned on an issues.
- uses: agathongroup/action-notify-via-issue@v1
if: ${{ failure() }}
This will create an issue comment whenever the job fails. The comment / issue will @ mention the user whose interaction triggered the GitHub workflow to run.
- uses: agathongroup/action-notify-via-issue@v1
if: ${{ always() }}
with:
# Repository name with owner. For example, agathongroup/action-notify-via-issue
# Lodash template: no
# Default: ${{ github.repository }}
repository: ""
# The GitHub authentication token.
# Lodash template: no
# Default: ${{ github.token }}
token: ""
# The GitHub username to notify.
# Lodash template: no
# Default: ${{ github.actor }}
user: ""
# Notification will be skipped when this evaluates to "true"
# Lodash template: yes
# Default: "false"
skip_when: "false"
# The title used for the GitHub issue. Used to find existing issue to add
# subsequent comments to.
# Lodash template: yes
# Default: "${{ github.workflow }} notifications for ${{ github.actor }}"
title: ""
# Introduction body used when creating a new issue.
# Lodash template: yes
# Default: see `action.yml`
intro_body: ""
# Comment body used for notification.
# Lodash template: yes
# Default: see `action.yml`
comment_body: ""
Above, some values indicate "Lodash template: yes". These values are passsed
through Lodash template()
. This
gives a lot of flexibility to customize these values as they have the full
power of JavaScript. Additionally, the following context is passed to these
templates:
Some examples can be found in the defaults specified in action.yml.
Note: GitHub provides some variable replacement with things like ${{ github.repository }}
inside the workflow definition. These will be completed before the Lodash template is executed.
- Allow multiple users and pass through
template()
- Allow "ALL" users to notify all mentionable users
- Include duration of job like action-slack
- Include link to specific job that failed, using same API call above to get job id
- Install dependencies:
yarn install
- Make changes
- Run lint, tests, build:
yarn all
- Commit and push changes