You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
3.6 KiB
91 lines
3.6 KiB
# Screenshots
|
|
|
|
<p align="center"><img src="https://i.imgur.com/ub9EAEe.png"/>
|
|
<img src="https://i.imgur.com/DDQWJIy.png"/></p>
|
|
|
|
|
|
|
|
# Features
|
|
- **Directly prompt GPT3 with `!g <prompt>`**
|
|
|
|
- **Have conversations with the bot, just like chatgpt, with `!g converse`**. Conversations happen in threads!
|
|
|
|
- **Redo Requests**, A simple button after the GPT3 response allows you to redo the initial prompt you asked.
|
|
|
|
- **DALL-E Image Prompt Optimization**, given some text that you're trying to generate an image for, the bot will automatically optimize the text to be more DALL-E friendly!
|
|
|
|
- Change and view model parameters such as temp, top_p, and etc directly within discord.
|
|
- Tracks token usage automatically
|
|
- Automatic pagination and discord support, the bot will automatically send very long message as multiple messages, and is able to send discord code blocks and emoji, gifs, etc.
|
|
- A low usage mode, use a command to automatically switch to a cheaper and faster model to conserve your tokens during times of peak usage.
|
|
- Prints debug to a channel of your choice, so you can view the raw response JSON
|
|
- Ability to specify a limit to how long a conversation can be with the bot, to conserve your tokens.
|
|
|
|
|
|
# Requirements
|
|
`python3.9 -m pip install -r requirements.txt`
|
|
|
|
**I recommend using python 3.9!**
|
|
|
|
OpenAI API Key (https://beta.openai.com/docs/api-reference/introduction)
|
|
|
|
Discord Bot Token (https://discord.com/developers/applications)
|
|
|
|
You can learn how to add the discord bot to your server via https://www.ionos.co.uk/digitalguide/server/know-how/creating-discord-bot/
|
|
|
|
Both the OpenAI API key and the Discord bot token needed to be loaded into a .env file in the same local directory as the bot file.
|
|
|
|
You also need to add a DEBUG_GUILD id and a DEBUG_CHANNEL id, the debug guild id is a server id, and the debug channel id is a text-channel id in Discord. Your final .env file should look like the following:
|
|
|
|
```
|
|
OPENAI_TOKEN="<openai_api_token>"
|
|
|
|
DISCORD_TOKEN="<discord_bot_token>"
|
|
|
|
DEBUG_GUILD="974519864045756446" #discord_server_id
|
|
|
|
DEBUG_CHANNEL="977697652147892304" #discord_chanel_id
|
|
```
|
|
|
|
Optionally, you can include your own conversation starter text for the bot that's used with `!g converse`, with `CONVERSATION_STARTER_TEXT`
|
|
|
|
## Bot on discord:
|
|
|
|
- Create a new Bot on Discord Developer Portal:
|
|
- Applications -> New Application
|
|
- Generate Toker for the app (discord_bot_token)
|
|
- Select App (Bot) -> Bot -> Reset Token
|
|
- Toogle PRESENCE INTENT:
|
|
- Select App (Bot) -> Bot -> PRESENCE INTENT
|
|
- Add Bot the the server.
|
|
- Select App (Bot) -> OAuth2 -> URL Generator -> Select Scope: Bot
|
|
- Bot Permissions will appear, select the desired permissions
|
|
- Copy the link generated below and paste it on the browser
|
|
- On add to server select the desired server to add the bot
|
|
|
|
# Usage
|
|
|
|
`python3.9 main.py`
|
|
|
|
# Commands
|
|
|
|
`!g` - Display help text for the bot
|
|
|
|
`!g converse` - Start a conversation with the bot, like ChatGPT
|
|
|
|
`!g end` - End a conversation with the bot.
|
|
|
|
`!gp` - Display settings for the model (temperature, top_p, etc)
|
|
|
|
`!gs <setting> <value>` - Change a model setting to a new value
|
|
|
|
`!g <prompt>` Ask the GPT3 Davinci 003 model a question.
|
|
|
|
`!gu` Estimate current usage details (based on davinci)
|
|
|
|
`!gs low_usage_mode True/False` Turn low usage mode on and off. If on, it will use the curie-001 model, and if off, it will use the davinci-003 model.
|
|
|
|
`!imgoptimize <image prompt text>` Optimize a given prompt text for DALL-E image generation.
|
|
|
|
`!delete_all_conversation_threads` - Delete all threads related to this bot across all servers.
|