DEV Community

Cover image for I Made a Discord Bot to Keep Hate Speech OUT of Your Server... And Everyone Else's!
Jasper Stephenson
Jasper Stephenson

Posted on • Originally published at jasperstephenson.com

I Made a Discord Bot to Keep Hate Speech OUT of Your Server... And Everyone Else's!

Add Safespace to your server!

"Go back to where you came from" is dominating headlines as I write this post; it seems like unabashed vitriol and prejudice is in fashion in the late '10s. I get sad reading the news lately, and when I get sad about a situation, I want to make things to change it. So, I built a bot that tracks hate speech and hate speech users across the whole Discord platform.


I was recently inspired by a Reddit bot.

Reddit bot

It searches through any given user's comment history on Reddit for the N word, and calls them out publicly. I thought this was a fantastic idea. In order to make a tolerant, accepting community, it's important to hold people accountable for their words and to make a clear statement that hate speech is not okay.

Then I thought about this recent debacle in the Super Smash Brothers scene. An up-and-coming competitor was caught using racial slurs in Discord.

Reddit hate speech

She was summarily cancelled, and rightly so.

However, these messages in the screenshot had to be manually searched for. Who knows how much hate speech is being ignored on Discord simply because no one has ever bothered to look for it?


...Hang on, doesn't that sound like something a bot could do? That thought got me started, and before long I saw a few opportunities:

  1. Reddit is a massive ecosystem where everything is public, but on Discord there are many discrete servers, making it easy for hate speech users to hide. Wouldn't it be cool to make a bot that can keep track of hate speech users across the entire Discord system?
  2. The Reddit bot was by request only. Wouldn't it be nicer to have automatic tracking of hate speech in your server, without having to know who exactly to look up?
  3. On top of that, wouldn't it be great if you could be alerted when a hate speech user joins your server, or when someone in your server uses hate speech elsewhere?

With those main design goals, I got to work.

Clarity and Confrontation

When someone uses hate speech on a server using SafeSpace, the bot immediately logs the infraction, deletes the message, and replies sternly.

Auto-reply

The admins of that server are also notified immediately.

Notifications

Admins of other servers that user is in (that are also running SafeSpace) are notified 24 hours later, unless the offender has been forgiven by their admin in that time.

Other server notifications

On the other end, if a normal server member wants to check on hate speech users in the server, they can.

List of offenders

They also have the power to see exactly what hate speech their fellow server member has used, and when.

Auto-reply

Tracking Across Servers

SafeSpace keeps a server-agnostic database of offenders. That alone sets it apart from most moderation bots, because it can warn admins and other members about hate speech users even if they haven't used hate speech in that specific server yet.

Auto-reply

The beauty of this bot lies in the fact that the more servers use it, the better it gets at rooting out hate speech users across the entire Discord network. With every server added, the more likely a hate speech user is to be caught, and the more servers can be notified when their members use hate speech, and the more servers will know when a hate speech user joins.Its effectiveness scales exponentially with adoption, so add it to your server! You never know what it might catch.

Leaving No Stone Unturned

When SafeSpace is added to a server, it searches the chat history for hate speech. These past infractions are also quietly saved.

Treading Softly

Not every user in the server needs to have someone else's hate speech paraded around in front of their face; in fact, this will likely strike a more negative tone in the server overall. In cases such as hate speech by a server member in a different server, or a tracked offender joining the server, the bot only messages the server admin, and allows them to use their own discretion toward the offender.

Words have context, and there will always be times when an infraction shouldn't be treated harshly. That's why the bot also allows server admins to forgive users for hate speech used on their server.

Forgiveness


Add SafeSpace to your Discord server now!

If you're curious, the whole project is open source, so you can check out the repository on Github.

If you're feeling generous, you could also donate to help out with server costs. :)

Also, if you liked this bot, check out my Timezone Bot for Discord!

Thanks for reading!

(Crosspost from my personal website.)

Top comments (0)