This is an open-source quote bot written in JavaScript, using Discord.js as a client and Firebase Cloud Firestore as a database service. The goal of this project is to be both extensible and easy to setup.
Basic rights (read/save) are available to everyone.
Advanced rights (edit/delete) are available to selected users called "captains".
I called this privilege level that way to prevent any confusion with the term "server admins".
Captains are not server admins, server admins are not captains.
Every commands and outputs can be customized heavily in config.json as presented here.
Head to the "Usage" section for more info.
Let's go!
First we need to create a Discord app and its associated bot
-
Create a new Discord app and give it a fancy name.
-
Go to the bot settings and add a bot.
-
In the OAuth2 URL Generator settings, set the scope to
application.commands
-
Copy the generated link and open it to your browser to add the bot to your server.
Now in order to run the project, you will need to have the following environment variables set:
- Your app OAuth2 client ID as
CLIENT_ID
. - Your bot token as
TOKEN
. - Your server ID as
GUILD_ID
. - At least one user ID in
CAPTAIN_IDS
(for more advanced rights)
You can add as many captains as you'd like but I recommend you keep it minimal.
There are several ways to store these values. I personnally put them in a .env
file in the config
directory.
Grab the latest release and create a .env
file in src/config
:
$ git clone git@github.com:r4dixx/discord-quotebot.git
$ cd discord-quotebot/src
$ touch config/.env
$ echo "CLIENT_ID=your_app_oauth2_client_id
TOKEN=your_bot_token
GUILD_ID=your_server_id
CAPTAIN_IDS=your_user_id, another_user_id, and_maybe_another" >> config/.env
**Don't share these info with anyone or you'll be open to malicious attacks! **
Now we're going to use a simple NoSQL cloud database to store our quotes.
Firebase Cloud Firestore is a good candidate for this kind of use case.
It's pretty simple:
-
Create a new Firebase project and navigate to the "Firestore Database" section
-
Create a database in production mode with the appropriate Cloud Firestore location (e.g.
eur3 (europe-west)
). -
Choose an ID for your collection (e.g.
quotes
) and declare it in your.env
file as follows:COLLECTION_ID=quotes
. The name you chose will appear as such in the Firestore console.
Your .env
file should look like this:
# Discord
CLIENT_ID=your_app_oauth2_client_id
TOKEN=your_bot_token
GUILD_ID=your_server_id
CAPTAIN_IDS=your_user_id
# Firebase
COLLECTION_ID=your_collection_name
Almost there! We just need to link up your Firebase project to your Discord bot.
-
Head to your project settings and navigate to the "Service Accounts" section
-
Click on
Create service account
andGenerate new private key
(this will download a*.json
file for you) -
Move the downloaded file to the config directory and make sure to rename it
firebase.json
. Do not share it with anyone!
That's it! Now we can go to the last step.
-
Users declared as captains are not server admins, they are just users with the right to edit/delete quotes. In a similar fashion, server admins cannot edit/delete quotes unless they are specifically declared as captains.
-
Never EVER share your environment with anyone. See why.
-
Everything in
firebase.json
must remain strictly confidential. In a similar fashion, your Cloud Firestore security rules should be strictly in production mode. See why. -
Refer to the official documentations if you're lost
Make sure you have Node.js 16.6 or higher installed and run the following commands:
$ cd discord-quotebot/src
$ npm install
$ npm start
This will:
- Install all the dependencies
- Deploy commands to your server
- Start the bot
Your log output should read the following:
Successfully reloaded application commands
which confirms that the commands have been deployed to your server.Discord client ready! Logged in as QuoteBot-Test - ID: your_client_id
which confirms that the bot is running.Instance of Firebase Cloud Firestore initalized properly
which confirms that the database is ready.
If you didn't get these three messages, something went wrong.
- Check the location of your
.env
file - Double check your environment variables.
- Triple check your Firebase project configuration.
If this still doesn't fix your problem, please open an issue.
Send /ping
in your Discord server and see the magic happen.
If nothing shows, something went wrong. Check the logs for potential error messages.
Please open an issue if you see anything unusual.
All good? Now you can customize the bot by editing config.json.
This file in JSON format contains every commands and their associated configuration.
Here's an example:
{
"add": {
"name": "add",
"description": "Add given quote to the collection",
"option": {
"name": "quote",
"description": "Enter a quote you would like to add"
},
"reply": {
"success": ":brain: **I'll remember this one...**",
"error": {
"mention": ":shushing_face: Not saving this one. Please don't mention people in quotes.",
"duplicate": ":people_holding_hands: Error: This quote already exists."
}
}
}
}
Everything can be customized pretty heavily so be creative!
Once you're done, save the file and restart the bot to deploy your new configuration.
Show me what you've done π€
/quote
to get a random quote/save
to save a quote/help
to get a list of available commands/ping
to test if the bot is running
-
Edit
/edit
last
new_quote
to edit last saved quote/edit
item
old_quote
new_quote
to edit a specific quote
-
Delete
/delete
last
to delete last saved quote/delete
item
quote
to delete a specific quote
Remember the dashboard? It's a great way to manage your collection. You can find it here
and access it anytime you want. No need to touch this folder again!
From there you can add, edit and delete documents very easily. You can even change creation dates!
Two things to note:
- Adding new fields to a document does nothing and can lead to issues. Please only use existing fields.
- Editing IDs is not recommended. This might break your bot.
Have fun π
Psst! If this is unclear for you: in the Cloud Firestore world collections are some kind of sub-databases, documents are tables and fields are entries
- Website: r4dixx.github.io
- Twitter: @r4dixx
- Github: @r4dixx
- LinkedIn: @r4dixx
Contributions, issues and feature requests are welcome!
Feel free to check the issues page.
Give a βοΈ if you liked this project!
Copyright Β© 2021 r4dixx.
This project is GPL-3.0 licensed.
This README was partially generated using readme-md-generator