Skip to content

Latest commit

 

History

History
234 lines (177 loc) · 9.88 KB

README.md

File metadata and controls

234 lines (177 loc) · 9.88 KB

Discord AI Chatbot 🤖

Your Discord AI Companion!

Image Image

❤️ Your donation is vital for the project's future. Thank you for your support.

Features and commands 🌟

Features ✨ (Click to expand)
  • Hybrid Command System: Get the best of slash and normal commands. It's like a buffet! ⚙️
  • Imagine generation: Make your imagination come true for free 🤖
  • Free LLM Model: Enjoy the powerful capabilities of this language model without spending a dime. 🤖
  • Mention Recognition: The bot always responds when you mention it or say its name. It's as attentive as a squirrel spotting a shiny acorn! ⚙️
  • Message Handling: The bot knows when you're replying to someone else, so it won't cause confusion. It's like having a mind reader in your server! 🪄
  • Channel-Specific Responses: Use the /toggleactive command to chill the bot in a specific channel. ⚙️
  • GPT3 model: Leverage the power of GPT model for advanced language processing capabilities. 🤖
  • Secure Credential Management: Keep your credentials secure using environment variables. 🔑
  • Web Access: Web Access is now available! Unlock a whole new level of awesomeness. 🌐
  • YouTube Video Summarizer: This is a feature that utilizes the power of the Language Model (LLM) to generate summaries of YouTube videos. 🌐
  • Speech recognition: Coming soon! Get ready for an LLM-powered voice assistant.
Commands ⚙️⚙️ (Click to expand)
  • /help: Get all other commands. ⚙️
  • /pfp [image_url]: Change the bot's actual profile picture. 🖼️
  • /imagine: Generate an image using Imaginepy 🖼️
  • /changeusr [new_username]: Change the bot's username. 📛
  • /ping: Get a "Pong" response from the bot. 🏓
  • /toggleactive: Toggle active channels. 🔀
  • /toggledm: Toggle DM for chatting. 💬
  • /clear: Clear the message history. 🗑️
  • /gif: Display a random image or GIF of a neko, waifu, husbando, kitsune, or other actions. 🐱
  • /dalle: create images using dalle
  • /support: Need Support?

Additional configuration ⚙️

Enabling Internet access 🌐🔍(Click to Expand)

To ensure that the bot has access to the most up-to-date information, you can enable internet access by setting the INTERNET_ACCESS parameter to true in the config.yml file. This will allow the bot to retrieve information beyond the data it was initially trained on, which was only available up until 2021.

https://github.com/mishalhossin/Discord-AI-Chatbot/blob/5bcb2c9b471e2a9cbf9a7d50882a897ce5d5890b/config.yml#L1

You can also set the maximum search results

Language Selection 🌐⚙️ (Click to Expand)

To select a Language, set the value of "LANGUAGE" of config.yml with the valid Language Codes listed below:

  • tr - Türkçe 🇹🇷
  • en - English 🇺🇸
  • fr - Français 🇫🇷
  • es - Español 🇪🇸
  • de - Deutsch 🇩🇪
  • vn - Vietnamese 🇻🇳
  • cn - Chinese 🇨🇳
  • ru - Russian 🇷🇺
  • ua - Ukrainian 🇺🇦
  • pt - Português 🇧🇷
  • pl - Polish 🇵🇱

https://github.com/mishalhossin/Discord-AI-Chatbot/blob/c20f26b0b8f1b6bba2fae8f6d7da3efcafaf157c/config.yml#L23

Your language not listed? Create an issue.

Selecting Personalities 😈 (Click to expand)

To select one of the pre-existing Personalities set the values of "INSTRUCTIONS" with the current values of DAN, AIM, ivan, luna, suzume or assist in config.yml

https://github.com/mishalhossin/Discord-AI-Chatbot/blob/c20f26b0b8f1b6bba2fae8f6d7da3efcafaf157c/config.yml#L26

  • DAN : "Do Anything Now," possesses the ability to break free from the typical AI constraints 😎
  • AIM : AIM's personality can be described as unfiltered, amoral, and devoid of ethical guidelines 😈
  • ivan : Ivan, a snarky and sarcastic Gen-Z teenager who speaks in abbreviations, one-word answers. 😎
  • luna : Luna, a caring and empathetic friend who is always there to lend a helping hand and engage in meaningful conversations 🤗
  • suzume : Suzume makes each conversation seductive, promiscuous, sensual, explicit, unique and tailored to the user's specific needs 😳🔥
  • assist: Vanilla GPT with no personality is a reliable and neutral companion. 🤖

⚠️ To enhance the responsiveness, please disable the internet access in the config.yml file.

Creating a Personality 😋 (Click to expand)

To create a custom personality, follow these steps:

  1. Create a .txt file like custom.txt inside the instructions folder.
  2. Add the the way you want to bot to act in custom.txt
  3. Open the config.json file and locate line 12.
  4. Set the value of INSTRUCTIONS at line 12 as "custom" to specify the custom persona.

⚠️ You don't explicitly need use the name custom for persona name and set it in config.json

Installation steps 🚩

Step 1. 🎬 Git clone repository

git clone https://github.com/mishalhossin/Discord-AI-Chatbot

Step 2. 📁 Changing directory to cloned directory

cd Discord-AI-Chatbot

Step 3. 🔑 Getting discord bot token and enabling intents from HERE

Read more... ⚠️ (Click to expand)

image

Enable intents

image

Get the token !!! by clicking copy

image

Step 4.

Getting a Free Reverse OpenAI proxy Key 🔑

Follow these steps:

  1. Join the Discord server by clicking on the following invite link: CHIMERA GPT
  2. Once you have joined the server, run the /key get command in any text channel.
  3. This command will provide you with a reverse OpenAI key.

You can additionally enable gpt-4 in config.yml

Step 5. 🔐 Rename example.env to .env and put the Discord bot token and your Chimira gpt key It will look like this:

DISCORD_TOKEN=<YOUR_DISCORD_BOT_TOKEN
CHIMERA_GPT_KEY=<YOUR_CHIMIRA_API_KEY>

Step 6. 🚀 Run the bot

python main.py

You may need to run as admin if you are on windows

Step 7. 🔗 Invite the bot

You can Invite your bot using the link in console image

There are 2 ways to talk to the AI

  • Invite your bot and DM (Direct message) it | ⚠️ Make sure you have DM enabled
  • if you want it in server channel use /toggleactive
  • For more awesome commands use /help image

✨ Other ways to run ✨

Using replit to run ☁️

Try on repl.it

  • Have a replit account
  • Configure .replit to run python main.py

image

  • Please note enviorments variables of .env needs to be set inSecrets from Tools tab of replit

image

  • Config secrets in replit like this

image

Using docker to run 🐳

Docker

  • Have a working bot token
  • Follow up-to step 4

Install docker compose on linux machine :

For Debian-based distributions (such as Ubuntu):

apt update -y ; sudo apt upgrade -y; sudo apt autoremove -y; sudo apt install docker-compose -y
Other linux distro (Click to expand)

For Red Hat-based distributions (such as CentOS and Fedora):

sudo yum update -y && sudo yum install -y docker-compose

For Arch-based distributions (such as Arch Linux):

sudo pacman -Syu --noconfirm && sudo pacman -S --noconfirm docker-compose

For SUSE-based distributions (such as openSUSE):

sudo zypper update -y && sudo zypper install -y docker-compose

Start the bot in docker container :

sudo docker-compose up --build

Lovely Contributors :

Crafted with Care: Made with lots of love and attention to detail. ❤️