For any problems running this specific bot: Discord Project Post
For general OpenAI API problems or questions: Discord API Discussions
For bugs in the template code: create an Issue
For feature requests: this repo is not accepting feature requests, you can discuss potential features in Discord Project Post
For PRs: only bug fix PRs wil be accepted. If you are implementing a new feature, please fork this repo.
Thank you!
Example Discord bot written in Python that uses the chat completions API to have conversations with the gpt-3.5-turbo
model, and the moderations API to filter the messages.
This bot uses the OpenAI Python Library and discord.py.
/chat
starts a public thread, with amessage
argument which is the first user message passed to the bot. You can optionally also adjust thetemperature
andmax_tokens
parameters.- The model will generate a reply for every user message in any threads started with
/chat
- The entire thread will be passed to the model for each request, so the model will remember previous messages in the thread
- when the context limit is reached, or a max message count is reached in the thread, bot will close the thread
- you can customize the bot instructions by modifying
config.yaml
- you can change the model, the default value is
gpt-3.5-turbo
- Copy
.env.example
to.env
and start filling in the values as detailed below - Go to https://beta.openai.com/account/api-keys, create a new API key, and fill in
OPENAI_API_KEY
- Create your own Discord application at https://discord.com/developers/applications
- Go to the Bot tab and click "Add Bot"
- Click "Reset Token" and fill in
DISCORD_BOT_TOKEN
- Disable "Public Bot" unless you want your bot to be visible to everyone
- Enable "Message Content Intent" under "Privileged Gateway Intents"
- Click "Reset Token" and fill in
- Go to the OAuth2 tab, copy your "Client ID", and fill in
DISCORD_CLIENT_ID
- Copy the ID the server you want to allow your bot to be used in by right clicking the server icon and clicking "Copy ID". Fill in
ALLOWED_SERVER_IDS
. If you want to allow multiple servers, separate the IDs by "," likeserver_id_1,server_id_2
- Install dependencies and run the bot
You should see an invite URL in the console. Copy and paste it into your browser to add the bot to your server. Note: make sure you are using Python 3.9+ (check with python --version)
pip install -r requirements.txt python -m src.main
- If you want moderation messages, create and copy the channel id for each server that you want the moderation messages to send to in
SERVER_TO_MODERATION_CHANNEL
. This should be of the format:server_id:channel_id,server_id_2:channel_id_2
- If you want to change the personality of the bot, go to
src/config.yaml
and edit the instructions - If you want to change the moderation settings for which messages get flagged or blocked, edit the values in
src/constants.py
. A higher value means less chance of it triggering, with 1.0 being no moderation at all for that category.
Why isn't my bot responding to commands?
Ensure that the channels your bots have access to allow the bot to have these permissions.
- Send Messages
- Send Messages in Threads
- Create Public Threads
- Manage Messages (only for moderation to delete blocked messages)
- Manage Threads
- Read Message History
- Use Application Commands