DiscordSRV

DiscordSRV

86.8k Downloads

DiscordSRV

DiscordSRV

The most powerful, configurable, widely loved, open-source Discord bridge plugin out there.

Player/server statistics

Intended usage

Using this plugin, you are able to give players the ability to chat in-game to chat with players on your Discord server as well as having people on the Discord server be able to chat with people on the server- this is useful for the situation of someone not being at their computer and being able to talk in-game.

As well as that, this plugin also has a remote console feature. You can designate a text channel for the plugin to listen on where messages sent to that channel are run as commands by the server console. You should restrict sending this channel to a developer or high ranking role only. Due to how Discord's permissions work, though, you can have some server roles being able to see the console, yet not being able to send messages in that channel, thus creating a read-only console for trusted staff members.

Both the chat and console link are toggleable through the configuration file. Some, but not all, options can be refreshed with /discord reload, by an op. VanishNoPacket permissions like silent join/quit, fake join/quit and join without announcing are checked when sending player join messages in the chat channel.

Install

It's recommended to go to DiscordSRV's wiki at https://github.com/Scarsz/DiscordSRV/wiki/Installation for picture instructions or watch one of the vidoes below to walk you through the installation.

If you want a straight-forward install, though, you can just follow these steps:

  1. Create a new application at https://discordapp.com/developers/applications/
  2. On the application's page, go to the "Bot" tab, click "Add Bot", and confirm
    • Optional: set your bot's avatar. If you don't do it now, you can later by command.
  3. Enable the SERVER MEMBERS INTENT and MESSAGE CONTENT INTENT options under "Privileged Gateway Intents" on the bot tab
  4. Click the copy button under "Token" on the bot tab, we'll be using it later
  5. Install the plugin, run & stop the server, then open the configuration file
  6. Paste the token you copied earlier into the BotToken value
  7. Go to https://scarsz.me/authorize & paste your application's Client ID value to the page
    • Find your client ID in the "General Information" tab
  8. In the config option labeled Channels, input the Discord channel ID you want to be for your chat under "global"- you can set more channels up here and their linked channels.
    • If you are using TownyChat, change the channel to "general" instead of "global"
    • For reference, to obtain a channel ID, go to the cog on the bottom left of Discord, go to the appearance tab, enable developer mode. From there you can right click a guild, channel, user, or role and there will be a "Copy ID" option
  9. Optionally add a console channels ID in the config to access your server console from Discord
  10. Run through all the config options, you'll be surprised with how many features this plugin has
  11. Profit

Supported plugins

DiscordSRV implements with a fair amount of plugins for chat and vanish functionality. We recommend VentureChat by Aust1n46 but plugins such as Herochat, VentureChat, Essentials, Premium/Super vanish, VanishNoPacket, and Multiverse all have functionality in DiscordSRV.

Commands/permissions

/discord

All of DiscordSRV's commands can be exposed from /discord. This includes but isn't limited to /discord toggle which toggles sending Discord messages back/forth for you- tell your players about this command!

discordsrv.chat

Allows people to have their chat sent to Discord. Go figure. Given by default, only exists so you can negate this permission from people/groups.

OP

All the admin commands for DiscordSRV require you to be an OP. To see the help, run /discordsrv in-game.

FAQ

How do I fix the error "Unsupported major.minor version 52.0?"

Update the server's Java JRE version to Java 8. <1.8 is unsupported.

I reloaded the plugin/server and now it won't work

DON'T RELOAD THE PLUGIN. IT BREAKS IT.

When I join/quit my server, a message isn't sent in the chat channel for me. What gives?

You have one of VanishNoPacket's/Essentials' permissions to join/quit silently. To disallow this, give yourself or the group one of the following depending on what you want to allow.

-discordsrv.silentjoin
-discordsrv.silentquit

Donations

First off, thank you from the bottom of my heart for the pizza. If you would like to donate, go to https://paypal.me/Scarsz. $10 is the suggested amount but you can donate however much you would like- anything is a massive thank you from me. In the note put your Discord username and if you're in DiscordSRV's server you'll be set as a donator and you'll receive some neat perks in the future. If you donated without the note, send me a PM on Discord and I'll manually check it.

Developers

If you want to interface DiscordSRV with your plugin, you can do so by adding the Maven dependency or adding the plugin jar to your project. For an example of this, see https://github.com/Scarsz/DiscordSRV-ApiTest. Be sure to add "DiscordSRV" to your plugin's plugin.yml depends/softdepends list.

Data usage

Data collection

Anything and everything shown at https://bstats.org/plugin/bukkit/DiscordSRV will be visible to the public with your server included in the statistics. This is only for statistics, no private information of your server is sent. If you don't want your server included in this, specify the config option "MetricsDisabled" and set it to "true" in the config.

Update checking

I have absolutely no clue why you would want to disable this, but if you do, set the "UpdateCheckDisabled" config option to "true".