/Discord-AI-Chatbot

This Discord chatbot is incredibly versatile, offering a wide range of customization options. It possesses the ability to detect images, access the internet, generate images, and even provide comprehensive summaries of YouTube videos

Primary LanguagePythonGNU Affero General Public License v3.0AGPL-3.0

Discord AI Chatbot πŸ€–

Your All-in-One Discord AI Companion!

❀️ 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. πŸ€–
  • Image Detection Model: The bot can detect objects and text in images with OCR and GPT2 captioning using a fancy Hugging Face API. πŸ•΅οΈβ€β™‚οΈ
  • 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. πŸ” Rename example.env to .env and put the Discord bot token It will look like this:

DISCORD_TOKEN=token_from_step_3

Step 5. πŸš€ Run the bot

python main.py

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

Step 6. πŸ”— 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. ❀️