upgrade bot + some new features (images, models)
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@ -1 +1,3 @@
|
|||||||
/.env
|
/.env
|
||||||
|
/__pycache__/
|
||||||
|
/geckodriver.log
|
||||||
|
171
bot.py
171
bot.py
@ -3,59 +3,160 @@
|
|||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import random
|
import random
|
||||||
import discord
|
from functools import reduce
|
||||||
|
|
||||||
from dotenv import load_dotenv
|
from dotenv import load_dotenv
|
||||||
|
|
||||||
|
import discord
|
||||||
|
from discord import Intents
|
||||||
|
from discord.ext import commands
|
||||||
|
|
||||||
|
from scraper import Girls
|
||||||
|
|
||||||
load_dotenv()
|
load_dotenv()
|
||||||
TOKEN = os.getenv("DISCORD_TOKEN")
|
TOKEN = os.getenv("DISCORD_TOKEN")
|
||||||
GUILD = os.getenv("DISCORD_GUILD") # Zocken mit Heidi
|
GUILD = os.getenv("DISCORD_GUILD") # Zocken mit Heidi
|
||||||
|
|
||||||
client = discord.Client()
|
|
||||||
|
class HeidiClient(discord.Client):
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__(intents=Intents.default(), status="Nur eine kann Germany's next Topmodel werden!")
|
||||||
|
|
||||||
|
self.prefix = "Heidi, "
|
||||||
|
self.prefix_regex = "^" + self.prefix
|
||||||
|
|
||||||
|
self.girls = Girls() # scraped model list
|
||||||
|
|
||||||
|
self.triggers = {} # automatic actions
|
||||||
|
self.triggers[lambda m: m.author.nick in self.girls.get_in_names()] = self.autoreact_to_girls
|
||||||
|
|
||||||
|
self.matchers = {} # react to messages
|
||||||
|
self.matchers["Hilfe$"] = self.show_help
|
||||||
|
self.matchers["Heidi!$"] = self.say_name
|
||||||
|
self.matchers["wer ist dabei\\?$"] = self.list_models_in
|
||||||
|
self.matchers["wer ist raus\\?$"] = self.list_models_out
|
||||||
|
self.matchers[".+, ja oder nein\\?$"] = self.magic_shell
|
||||||
|
self.matchers["wähle: (.+,)+"] = self.choose
|
||||||
|
self.matchers["gib Bild von .+"] = self.show_model_picture
|
||||||
|
|
||||||
|
|
||||||
@client.event
|
### Helpers ------------------------------------------------------------------------------------
|
||||||
async def on_ready():
|
|
||||||
print(f"{client.user} has connected to Discord!")
|
|
||||||
|
|
||||||
guild = discord.utils.get(client.guilds, name=GUILD)
|
def _help_text(self):
|
||||||
print(f"{client.user} is connected to the following guild:")
|
"""
|
||||||
print(f"{guild.name} (id: {guild.id})")
|
Generate help-string from docstrings of matchers and triggers
|
||||||
|
"""
|
||||||
|
docstrings_triggers = [" - " + func.__doc__.strip() for func in self.triggers.values()]
|
||||||
|
docstrings_matchers = [" - " + func.__doc__.strip() for func in self.matchers.values()]
|
||||||
|
|
||||||
|
response = "Präfix: \"" + self.prefix + "\" (mit Leerzeichen)\n"
|
||||||
|
response += "--------------------------------------------------\n"
|
||||||
|
|
||||||
|
response += "Das mache ich automatisch:\n"
|
||||||
|
response += "\n".join(docstrings_triggers)
|
||||||
|
|
||||||
|
response += "\n\nIch höre auf diese Befehle:\n"
|
||||||
|
response += "\n".join(docstrings_matchers)
|
||||||
|
|
||||||
|
return response
|
||||||
|
|
||||||
|
|
||||||
heidis_girls = ["Ana", "Soulin", "Alysha", "Luca", "Maria"]
|
def _match(self, matcher, message):
|
||||||
|
"""
|
||||||
cmd_prefix = "^Heidi, "
|
Check if a string matches against prefix + matcher (case-insensitive)
|
||||||
cmd_listing = {"HEIDI!": "Ich sage enthusiastisch meinen Namen", "*?": "Ich beantworte eine Frage"}
|
"""
|
||||||
|
return re.match(self.prefix_regex + matcher, message.content, re.IGNORECASE)
|
||||||
|
|
||||||
|
|
||||||
@client.event
|
### Events -------------------------------------------------------------------------------------
|
||||||
async def on_message(message):
|
|
||||||
if message.author == client.user:
|
|
||||||
return
|
|
||||||
|
|
||||||
### Passive Actions ----------------------------------------------------------------------------
|
async def on_ready(self):
|
||||||
|
print(f"{self.user} (id: {self.user.id}) has connected to Discord!")
|
||||||
|
|
||||||
|
|
||||||
|
async def on_message(self, message):
|
||||||
|
if message.author == client.user:
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
for trigger in self.triggers:
|
||||||
|
if trigger(message):
|
||||||
|
await self.triggers[trigger](message)
|
||||||
|
break
|
||||||
|
|
||||||
|
|
||||||
|
for matcher in self.matchers:
|
||||||
|
if self._match(matcher, message):
|
||||||
|
await self.matchers[matcher](message)
|
||||||
|
break
|
||||||
|
|
||||||
# React to girls message
|
|
||||||
if message.author.nick in heidis_girls:
|
|
||||||
await message.add_reaction("❤")
|
|
||||||
|
|
||||||
### Commands -----------------------------------------------------------------------------------
|
### Commands -----------------------------------------------------------------------------------
|
||||||
|
|
||||||
# Help: Heidi, Hilfe
|
async def show_help(self, message):
|
||||||
if re.match(cmd_prefix + "Hilfe$", message.content):
|
"""
|
||||||
response = "Befehle für Heidi:\n" + str(cmd_listing)
|
Hilfe (Ich höre auf diese Befehle, Senpai UwU)
|
||||||
await message.channel.send(response)
|
"""
|
||||||
|
await message.channel.send(self._help_text())
|
||||||
# Say my name: Heidi, Heidi!
|
|
||||||
elif re.match(cmd_prefix + "Heidi!$", message.content):
|
|
||||||
response = "HEIDI!"
|
|
||||||
await message.channel.send(response)
|
|
||||||
|
|
||||||
# Magic Conch Shell
|
|
||||||
elif re.match(cmd_prefix + ".+\\?$", message.content):
|
|
||||||
choices = ["Ja!", "Jo.", "Total!", "Hab ich selbst gesehen!", "Nein!", "Nö.", "Nä.", "Niemals!", "Twitch Prime?"]
|
|
||||||
response = choices[random.randint(0, len(choices) - 1)]
|
|
||||||
await message.channel.send(response)
|
|
||||||
|
|
||||||
|
|
||||||
|
async def say_name(self, message):
|
||||||
|
"""
|
||||||
|
Heidi! (Ich sag meinen Namen)
|
||||||
|
"""
|
||||||
|
await message.channel.send("HEIDI!")
|
||||||
|
|
||||||
|
|
||||||
|
async def list_models_in(self, message):
|
||||||
|
"""
|
||||||
|
wer ist dabei? (Liste der Models welche noch GNTM werden können)
|
||||||
|
"""
|
||||||
|
await message.channel.send("\n".join(self.girls.get_in_names()))
|
||||||
|
|
||||||
|
|
||||||
|
async def list_models_out(self, message):
|
||||||
|
"""
|
||||||
|
wer ist raus? (Liste der Keks welche ich ge*ickt hab)
|
||||||
|
"""
|
||||||
|
await message.channel.send("\n".join(self.girls.get_out_names()))
|
||||||
|
|
||||||
|
|
||||||
|
async def show_model_picture(self, message):
|
||||||
|
"""
|
||||||
|
gib Bild von <Name> (Zeigt ein Bild des entsprechenden Models)
|
||||||
|
"""
|
||||||
|
name = message.content.split()[-1]
|
||||||
|
picture = discord.Embed()
|
||||||
|
picture.set_image(url=self.girls.get_image(name))
|
||||||
|
picture.set_footer(text=name)
|
||||||
|
await message.channel.send(embed=picture)
|
||||||
|
|
||||||
|
|
||||||
|
async def magic_shell(self, message):
|
||||||
|
"""
|
||||||
|
<Frage>, ja oder nein? (Ich beantworte dir eine Frage)
|
||||||
|
"""
|
||||||
|
choices = ["Ja!", "Jo.", "Total!", "Natürlich.", "Nein!", "Nö.", "Nä.", "Niemals!"]
|
||||||
|
await message.channel.send(random.choice(choices))
|
||||||
|
|
||||||
|
|
||||||
|
async def choose(self, message):
|
||||||
|
"""
|
||||||
|
wähle: <Option 1>, <Option 2>, ... (Ich treffe eine Wahl)
|
||||||
|
"""
|
||||||
|
choices = message.content.replace(",", "").split()[2:]
|
||||||
|
await message.channel.send(random.choice(choices))
|
||||||
|
|
||||||
|
|
||||||
|
### Automatic Actions --------------------------------------------------------------------------
|
||||||
|
|
||||||
|
async def autoreact_to_girls(self, message):
|
||||||
|
"""
|
||||||
|
Ich ❤-e Nachrichten einer aktiven GNTM Teilnehmerin
|
||||||
|
"""
|
||||||
|
await message.add_reaction("❤")
|
||||||
|
|
||||||
|
|
||||||
|
client = HeidiClient()
|
||||||
client.run(TOKEN)
|
client.run(TOKEN)
|
||||||
|
Reference in New Issue
Block a user