Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Markoudstaal/node-red-contrib-discord-advanced
Recieve, send, edit and delete Discord messages in node-red.
https://github.com/Markoudstaal/node-red-contrib-discord-advanced
Last synced: 3 months ago
JSON representation
Recieve, send, edit and delete Discord messages in node-red.
- Host: GitHub
- URL: https://github.com/Markoudstaal/node-red-contrib-discord-advanced
- Owner: Markoudstaal
- License: mit
- Created: 2021-07-17T19:00:53.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-06-07T20:24:35.000Z (5 months ago)
- Last Synced: 2024-07-08T01:04:24.723Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 461 KB
- Stars: 46
- Watchers: 8
- Forks: 16
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-nodered - discord-advanced - Interact with Discord, via Discord.js. (Nodes / Social)
README
# node-red-contrib-discord-advanced
[![npm version](https://badge.fury.io/js/node-red-contrib-discord-advanced.svg)](https://badge.fury.io/js/node-red-contrib-discord-advanced) ![](https://img.shields.io/static/v1?label=discord.js&message=14.11.0&color=brightgreen)
![](https://img.shields.io/static/v1?label=node&message=%3E=16.9.0&color=brightgreen)Node-red nodes that allow you to interact with Discord, via [Discord.js](https://discord.js.org).
Currently the following actions are supported:
* Receive messages from any Discord servers your BOT is in.
* Send messages in a specific channel.
* Send private messages to users.
* Send and edit embed messages.
* Add attachments to messages.
* Edit, reply, delete messages in a channel.
* Publish messages to announcements channels.
* React to messages with emojis.
* Listen for reactions on a message.
* Listen for interactions on a message button or select menu.
* Listen for interactions on commands.
* Submit modals.
* Set Status text of the Bot
* Get permissions of a specific user. Add and remove roles. Listen when a user joins or leaves a guild.
* Change channel's name.
* Allow full control over the BOT by access to the DiscordJS client.This repository builds on [node-red-contrib-discord](https://github.com/jorisvddonk/node-red-contrib-discord) by Joris vd Donk . The main intention is to add more features and keep the repository updated.
## Installation and documentation
The [Wiki](https://github.com/Markoudstaal/node-red-contrib-discord-advanced/wiki) is still being written when it comes to documentation but you can find a guide on how to install and setup the nodes [here](https://github.com/Markoudstaal/node-red-contrib-discord-advanced/wiki/Installation-and-setup).
## Nodes
node-red-contrib-discord-advanced gives you access to 10 nodes:
* **discordMessage** is a node with no inputs and one output allowing you to receive notifications of incoming messages.
* **discordMessageManager** allows (embed) messages to be sent to either channels or privatly to user. It also allows for editing and deleting of (embed) messages.
* **discordReactionManager** that allows you to listen to reactions on a message.
* **discordPermissions** allows you to check the permissions of a specifc user. This is useful when you get the user from another source than the discordMessage node. discorPermissions lets you to add role to an user and to remove role.
* **discordClient** is an advanced deprecated node with one input and one output allowing you to inject a references to a [Discord.js Client](https://discord.js.org/#/docs/main/stable/class/Client) into a message. This node can cause node-red to crash if you use it improperly, so take caution. Messages containing a Discord.js Client reference can *not* be forked (e.g. sent to two nodes), so you'll have to manually remove the reference to the Client via a function node using `delete msg.discord`.
* **discordInteraction** allows you to listen to commands, buttons and select menu interactions and to decide how to respond to them.
* **discordInteractionManager** allows you to edit interactions by id.
* **discordChannelName** allows you to change a channel's name.
* **discordMember** listens when a user joins or leaves a guild.
* **discordTyping** creates a 'bot is typing...' message on a channel.## Changelog
See `CHANGELOG.md` for more info, including information regarding breaking changes per version.
## Key migration points from 3.4.x to 3.5.0
### Native behavior of discord interactions
When a command is sent by an user, discord displays messages like "Bot is thinking...". Versions < 3.4 of node-red-contrib-discord-advanced manage this interaction by replying with a default text message.
From 3.5.0, this library always defers replies and updates, keeping in memory the reference to the interaction in order to interact moments later within the flow with the new node discordInteractionManager.### Replacing discordMessageManager for discordInteractionManager
Now all interactions are replied with discordInteractionManager node, so there are several scenarios for having in mind. This is a breaking change. It's mandatory to take a look on examples to prevent broken flows.[Examples](https://github.com/Markoudstaal/node-red-contrib-discord-advanced/wiki/Interaction-Examples)
## Privileged Intents for correct functioning
![](https://raw.githubusercontent.com/Markoudstaal/node-red-contrib-discord-advanced/main/assets/privileged_intents.png)
## Support, issues and feature requests
For support in setting up and feature requests you can contact me on [this](https://discord.gg/HPva4sjezt) discord.
Issues can also be reported there but prefferably via GitHub.## Discord.js client sharing
All nodes share Discord.js clients based on the `discord-token` that they were configured with. That means that, when you add many `discordMessage` nodes configured with the exact same token, only a single connection with Discord will be made.