Meet RinaBot—your new best friend on Discord! RinaBot isn’t just any bot; it’s packed with features to make your Discord server lively and fun. Whether you want anime updates, manga insights, character information, or even some quirky AI chat, RinaBot’s got you covered!
RinaBot operates using a user account rather than the standard bot API. This allows for a more flexible interaction with Discord but may violate Discord's Terms of Service. Please ensure you understand the implications and proceed with caution when using this method.
-
🎬 Anime & Manga Insights
-anime [title]
: Get the latest scoop on your favorite anime.-manga [title]
: Dive into the world of manga with detailed info.
-
🎥 Anime Recommendations
-rec
: Get personalized anime recommendations based on your preferences.
-
👾 Character Information
-ch [character name]
: Discover cool facts and details about your favorite characters.
-
🤖 Rina’s AI Chat
-rina [message]
: Have a chat with Rina, our character AI. It's like chatting with a virtual buddy!
-
📸 Image Magic
- Send an image, and RinaBot will download it and generate a snazzy caption for it. Perfect for spicing up your server with some visual flair!
- Sender Component: the sender component is now functional! but the ai restart every conv for some reason lol
it need some more work to run but main thing work without any problem
-
Connect to Discord: RinaBot hooks up with Discord using WebSocket to stay in sync with your server.
-
Handle Commands: Send commands like
-anime
or-rina
and watch RinaBot spring into action. It’s like having a personal assistant right in your chat! -
Process Images: Share images and let RinaBot work its magic by generating captions and keeping your community engaged with fun content.
-
AI Interaction: Chat with Rina and enjoy some light-hearted banter with our (model can be changed in the main code (look at the api file to ). Who knows what Rina might say next?
-
Clone the Repo:
git clone https://github.com/notkiyo/Rina-s-Realm.git cd Rina-s-Realm cd aiwaifu
-
Install Dependencies:
pip install -r requirements.txt
-
Configure Your Token:
- Set up your Discord bot token in
apicode.py
. Replace the placeholder values with your actual API keys and tokens.
- Set up your Discord bot token in
-
Run the Bot:
python main.py
-
Enjoy: Join your Discord server and start using RinaBot’s commands. Watch your server come to life!
- In Progress: This project is still a work in progress. The sender component is under construction, and we’re actively learning and refining it. Keep an eye out for updates!
- Modular Design: Some functionality is separated into standalone Python files for better organization and modularity. Check out
apicode.py
,imagetotext.py
, andanimeani.py
for more details.
To make RinaBot even more versatile, you can easily add new handlers or functionalities. Here's a quick guide on how to do that:
Start by creating a new Python file in the handlers
directory, or modify an existing one.
For example, if you're adding a new handler to fetch weather updates, create a weather_handler.py
file with the following code:
class WeatherHandler:
def __init__(self, discord_sender):
self.discord_sender = discord_sender
async def handle_weather(self, location, channel_id):
# Code to fetch weather data goes here
weather_info = await self.fetch_weather_data(location)
tagged_message = f"🌤 Weather Update for {location}: {weather_info}"
# Use send_tagged_message to send this message to a Discord channel
await self.discord_sender.send_tagged_message(tagged_message, channel_id)
async def fetch_weather_data(self, location):
# Implement your logic to fetch weather data
return "Sunny, 25°C" # Example response
To make use of send_tagged_message
and send results to Discord, modify your handler's response flow, as shown in the example above.
In your discord_sender.py
, ensure that the send_tagged_message
function can handle your new type of message tags:
class DiscordSender:
async def send_tagged_message(self, message, channel_id):
# Sending the message to the Discord channel using WebSocket or Discord API
await self.send_message(message, channel_id)
Finally, update the CommandHandler
class in command_handler.py
to include the new handler command. For example, if your weather command is -weather
, add it like this:
class CommandHandler:
def __init__(self, weather_handler):
self.weather_handler = weather_handler
async def handle_command(self, command, args, channel_id):
if command == '-weather':
location = ' '.join(args)
await self.weather_handler.handle_weather(location, channel_id)
Now, your bot will handle -weather
commands and send weather updates to your Discord channel using the send_tagged_message
method!
Got ideas for new features or improvements? We’re all ears! Fork the repo, make your changes, and submit a pull request. If you have a wild idea or a genius suggestion, let us know!
- Anilist API: For providing awesome anime and manga data.
- ImageCaptioning: For adding that extra touch of fun to image sharing!
- ChatGPT: Special thanks to ChatGPT for the invaluable assistance in structuring the code and README. Your guidance made this project better and more user-friendly!
Got an idea that could make RinaBot even cooler? Don’t keep it to yourself! Share your thoughts, and let’s make RinaBot the ultimate Discord sidekick. Maybe a mini-game or a custom meme generator? The sky’s the limit!
If you have any questions, want to chat, or just want to share your thoughts, feel free to reach out at [email protected].
This project is licensed under the Creative Commons Attribution 4.0 International License. You are free to share, remix, and build upon this work, even for commercial purposes, as long as you provide appropriate credit. For more details, check out the full license text here.
Happy Discord-ing! 🚀