Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Ilshidur/action-discord
🚀 GitHub Action that sends a Discord message.
https://github.com/Ilshidur/action-discord
github-action github-actions
Last synced: 3 months ago
JSON representation
🚀 GitHub Action that sends a Discord message.
- Host: GitHub
- URL: https://github.com/Ilshidur/action-discord
- Owner: Ilshidur
- License: mit
- Created: 2019-01-14T23:03:36.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-02-21T07:48:28.000Z (11 months ago)
- Last Synced: 2024-10-17T13:14:07.421Z (3 months ago)
- Topics: github-action, github-actions
- Language: JavaScript
- Homepage: https://github.com/marketplace/actions/actions-for-discord
- Size: 163 KB
- Stars: 404
- Watchers: 9
- Forks: 79
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-actions - Send a Discord notification
- fucking-awesome-actions - Send a Discord notification
- awesome-workflows - Send a Discord notification
- stars - Ilshidur/action-discord - 🚀 GitHub Action that sends a Discord message. \[*MIT License*\] (⭐️408) (JavaScript)
- stars - Ilshidur/action-discord - 🚀 GitHub Action that sends a Discord message. \[*MIT License*\] (⭐️406) (JavaScript)
README
# 🚀 Discord for GitHub Actions
[![Build Status][build-badge]][build-url]
Sends a Discord notification message. Simple as that.
Supports all [workflow event types](https://developer.github.com/webhooks/#events) by using the [Discord GitHub webhooks](https://discordapp.com/developers/docs/resources/webhook#execute-githubcompatible-webhook).*Appearance on Discord :*
![Discord message](preview.png "Discord message")
This GitHub action is part of a list of Actions that are located in an other repo. Feel free to check it out : https://github.com/Ilshidur/actions.
## Compatibility note
As this Action is containerized with Docker, [it can only run on Linux environments](https://help.github.com/en/actions/building-actions/about-actions#types-of-actions).
> Docker container actions can only execute in the GitHub-hosted Linux environment.
> Self-hosted runners must use a Linux operating system and have Docker installed to run Docker container actions. For more information about the requirements of self-hosted runners, see "About self-hosted runners."
## Usage
```yaml
- name: Discord notification
env:
DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }}
uses: Ilshidur/action-discord@master
with:
args: 'The project {{ EVENT_PAYLOAD.repository.full_name }} has been deployed.'
```**NOTICE :** for stability purposes, it is recommended to use the action with an explicit commit SHA-1 :
* Version : `uses: "Ilshidur/[email protected]"` (→ link to the releases list : https://github.com/Ilshidur/action-discord/releases)
* Commit SHA-1 : `uses: "Ilshidur/action-discord@0c4b27844ba47cb1c7bee539c8eead5284ce9fa9"` (→ link to the commits list : https://github.com/Ilshidur/action-discord/commits/master)### Arguments
By default, the GitHub action will send a notificaction with the event informations. Providing the arguments will override the message.
**Environment variables** can be interpolated in the message using brackets (`{{` and `}}`) :
e.g.: `Action called : {{ GITHUB_ACTION }}`
**Event Payload** data can also be interpolated in the message using brackets (`{{` and `}}`) with the `EVENT_PAYLOAD` variable.
e.g.: `Action called: {{ GITHUB_ACTION }} as {{ EVENT_PAYLOAD.pull_request.id }}`
> See the [event types](https://developer.github.com/v3/activity/events/types) for valid payload informations.
#### Examples
* `args = "Hello, beautiful ! I ran a GitHub Actions for you <3"`
* `args = "I showed you my commit. Please respond."`### Environment variables
* **`DISCORD_WEBHOOK`** (**required**): the Discord webhook URL (see https://support.discordapp.com/hc/en-us/articles/228383668-Intro-to-Webhooks).
* ***IMPORTANT !!* You MUST NOT append `/github` at the end of the webhook.**
* **`DISCORD_USERNAME`** (*optional*): overrides the bot nickname.
* **`DISCORD_AVATAR`** (*optional*): overrides the avatar URL.
* **`DISCORD_EMBEDS`** (*optional*): This should be a valid JSON string of an array of Discord `embed` objects. See the [documentation on Discord WebHook Embeds](https://birdie0.github.io/discord-webhooks-guide/structure/embeds.html) for more information. You can use set it to `${{ toJson(my_value) }}` using [`toJson()`](https://docs.github.com/en/actions/reference/context-and-expression-syntax-for-github-actions#tojson) if your input is an object value.
* That's all.## Alternatives
Because open source is about everyone :
https://github.com/marketplace/actions/discord-message-notify
![](https://img.shields.io/github/stars/appleboy/discord-action.svg?label=Stars&style=social)## TODO
* [Pass arguments with the `with` keyword](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/workflow-syntax-for-github-actions#jobsjob_idstepswith)
* Run outside of a container.
Don't forget to 🌟 Star 🌟 the repo if you like this GitHub Action !
Your feedback is appreciated[build-badge]: https://img.shields.io/endpoint.svg?url=https%3A%2F%2Factions-badge.atrox.dev%2FIlshidur%2Faction-discord%2Fbadge&style=flat
[build-url]: https://actions-badge.atrox.dev/Ilshidur/action-discord/goto