Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wearerequired/slack-messaging-action
💌 A GitHub Action for sending (and updating) messages of any layout and formatting from GitHub Actions to Slack.
https://github.com/wearerequired/slack-messaging-action
bot github-action slack
Last synced: 2 months ago
JSON representation
💌 A GitHub Action for sending (and updating) messages of any layout and formatting from GitHub Actions to Slack.
- Host: GitHub
- URL: https://github.com/wearerequired/slack-messaging-action
- Owner: wearerequired
- License: mit
- Created: 2020-10-02T12:03:19.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-05-01T04:43:53.000Z (9 months ago)
- Last Synced: 2024-10-27T13:28:12.646Z (3 months ago)
- Topics: bot, github-action, slack
- Language: JavaScript
- Homepage:
- Size: 793 KB
- Stars: 20
- Watchers: 3
- Forks: 8
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Slack Messaging Action
A GitHub Action for sending (and updating) messages of any layout and formatting from GitHub Actions to Slack. Inspired by [Slack Notify Build](https://github.com/marketplace/actions/slack-notify-build).
A [Slack bot token](https://api.slack.com/docs/token-types) is required to use this action, and the associated app must be granted permission to post in the channel, private group or DM you specify.
## Usage
```yaml
uses: wearerequired/slack-messaging-action@v2
with:
bot_token: ${{ secrets.SLACK_BOT_TOKEN }}
channel: deployments
payload: >-
{
"icon_emoji": ":rocket:",
"username": "Deployer",
"text": "Deployment finished.",
"attachments": [
{
"author_name": "${{ github.event.sender.login }}",
"author_link": "${{ github.event.sender.html_url }}",
"author_icon": "${{ github.event.sender.avatar_url }}",
"color": "good",
"fields": [
{
"title": "Revision",
"value": "",
"short": true
}
],
"footer": "",
}
]
}
```In `payload` you have to provide your own [rich message layout](https://api.slack.com/messaging/composing/layouts) which will be sent as is to Slack.
### Updating an existing message
If you prefer to update a single message instead of posting multiple messages, you can pass a `message_id` to future steps.
Note: You must assign a step `id` to the first Slack notification step in order to reference it for future steps:
```yaml
- name: Notify Slack about deployment start
if: success()
id: slack # IMPORTANT: Reference this step ID value in future Slack steps.
uses: wearerequired/slack-messaging-action@v2
with:
bot_token: ${{ secrets.SLACK_BOT_TOKEN }}
channel: deployments
payload: >-
{
"icon_emoji": ":rocket:",
"username": "Deployer",
"text": "Deployment started."
}- name: Deployment
- name: Notify Slack about deployment success
if: success() # You can use the conditional checks to determine which notification to send.
uses: wearerequired/slack-messaging-action@v2
with:
bot_token: ${{ secrets.SLACK_BOT_TOKEN }}
message_id: ${{ steps.slack.outputs.message_id }} # Updates existing message from the first step.
channel: deployments
payload: >-
{
"icon_emoji": ":rocket:",
"username": "Deployer",
"text": "Deployment finished."
}- name: Notify Slack about deployment fail
if: failure() # You can use the conditional checks to determine which notification to send.
uses: wearerequired/slack-messaging-action@v2
with:
bot_token: ${{ secrets.SLACK_BOT_TOKEN }}
message_id: ${{ steps.slack.outputs.message_id }} # Updates existing message from the first step.
channel: deployments
payload: >-
{
"icon_emoji": ":boom:",
"username": "Deployer",
"text": "Deployment failed."
}
```## Inputs
### `bot_token`
A [bot token](https://api.slack.com/docs/token-types) associated with a Slack app. **Required**
_Note_: The following bot token scopes are required: `chat:write`, `chat:write.customize`, `chat:write.public`, `channels:read`, and `groups:read`.
### `channel`
The name of the channel to post the message to. **Required** if no `channel_id` is provided.
_Note_: If your workspace has many channels, supplying only a `channel` may cause rate limiting issues with this GitHub Action. Consider supplying a `channel_id` instead.
### `channel_id`
The ID of the channel to post the message to. **Required** if no `channel` is provided, or if you need to send to a DM.
### `payload`
The [JSON payload of a message](https://api.slack.com/messaging/composing) to send. **Required**
_Note_: `channel` and `ts` are set to the values of the respective inputs.
### `message_id`
The ID of a previous Slack message to update instead of posting a new message. Typically passed using the `steps` context:
```yaml
message_id: ${{ steps..outputs.message_id }}
```## Outputs
### `message_id`
Returns the unique message ID, which is a timestamp which can be passed to future Slack API calls as `ts`.
## License
The scripts and documentation in this project are released under the [MIT license](LICENSE).
[![a required open source product - let's get in touch](https://media.required.com/images/open-source-banner.png)](https://required.com/en/lets-get-in-touch/)