Skip to content
This repository has been archived by the owner on Jun 20, 2023. It is now read-only.

Bridges a text channel between Slack and Discord

Notifications You must be signed in to change notification settings

HackSoc/slack-discord-bridge

Repository files navigation

slack-discord-bridge

Bridges a text channel between Slack and Discord

Setup

  1. Prerequisites

You need to have Node.js installed. This includes the runtime and the package manager required to install the dependencies.

  1. Clone the repository
git clone [email protected]:HackSoc/slack-discord-bridge.git
  1. Install dependencies
cd slack-discord-bridge
npm install
  1. Set up API keys

Make copies of discord.keys.js.example and slack.keys.js.example and remove the .example ending.

For Discord, you need to create an app, then click "create bot user". Copy the bot user token into the bot_token field of discord.keys.js.
Next you need to create a webhook for the Discord channel of your choice. Click "Edit channel" (gear icon next to a text channel) and go to the webhooks section of the menu. (Note you will need the "Manage Webhooks" permission on your Discord server). Copy the ID and token (explained in discord.keys.js) into the relevant fields.

For Slack, it's a little more complicated. Create a new app and choose your workspace from the list.
First go to OAuth & Permissions, and if you haven't already, add the bot to your workspace. Scroll to Scopes and add users.profile:read.
Save changes, then go to Bot Users and add a bot user.
Finally go back to OAuth & Permissions and install the app to your workspace.
Copy the OAuth and Bot tokens to the correct places in slack.keys.js.

Now you need to add an Incoming Webhook as a custom integration. Note that if you add this as part of the Slack app you created, the messages on Slack won't have the username or avatar of the Discord users sending them. Choose the channel you want the webhook to post in, and copy the URL to hook_url in slack.keys.js.

  1. Running

node bot.js will run the bot until you stop it with Ctrl-C, but you may wish to leave it running longer than you have a terminal window open. An application running in the background is called a daemon. One way of daemonising this bot is to use pm2. After you have installed it, just run pm2 start bot.js in the same directory as bot.js.

About

Bridges a text channel between Slack and Discord

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published