1
Fork 0
mirror of https://github.com/RYGhub/royalnet.git synced 2024-11-27 13:34:28 +00:00

Improved /discord

This commit is contained in:
Steffo 2017-03-23 19:43:26 +01:00
parent d61bdab524
commit 4dcf8d1134

View file

@ -38,23 +38,35 @@ async def diario(bot, update, arguments):
Devi essere un Royal per poter eseguire questo comando. Devi essere un Royal per poter eseguire questo comando.
Sintassi: `/diario <frase>`""" Sintassi: `/diario <frase>`"""
if not currently_logged_in(update).royal: # Check if the user is logged in
await update.message.reply(bot, "⚠ Non sei autorizzato a eseguire questo comando.", parse_mode="Markdown") if not currently_logged_in(update):
await update.message.reply(bot, "⚠ Non hai ancora eseguito l'accesso! Usa `/sync`.", parse_mode="Markdown")
return return
# Check if the currently logged in user is a Royal Games member
if not currently_logged_in(update).royal:
await update.message.reply(bot, "⚠ Non sei autorizzato a eseguire questo comando.")
return
# Check the command syntax
if len(arguments) == 0: if len(arguments) == 0:
await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/diario <random | markov | numerofrase>`", parse_mode="Markdown") await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/diario <random | markov | numerofrase>`", parse_mode="Markdown")
return return
# Check for non-ASCII characters
entry = " ".join(arguments) entry = " ".join(arguments)
if not entry.isprintable(): if not entry.isprintable():
await update.message.reply(bot, "⚠ La frase che stai provando ad aggiungere contiene caratteri non ASCII, quindi non è stata aggiunta.\nToglili e riprova!", parse_mode="Markdown") await update.message.reply(bot, "⚠ La frase che stai provando ad aggiungere contiene caratteri non ASCII, quindi non è stata aggiunta.\nToglili e riprova!")
return return
# Remove endlines
entry = entry.replace("\n", " ") entry = entry.replace("\n", " ")
# TODO: check if a end-of-file character can be sent on Telegram
# Generate a timestamp
time = update.message.date.timestamp() time = update.message.date.timestamp()
# Write on the diario file
file = open("diario.txt", "a", encoding="utf8") file = open("diario.txt", "a", encoding="utf8")
file.write(f"{int(time)}|{entry}\n") file.write(f"{int(time)}|{entry}\n")
file.close() file.close()
del file del file
await update.message.reply(bot, "Aggiunto al diario!", parse_mode="Markdown") # Answer on Telegram
await update.message.reply(bot, "✅ Aggiunto al diario!")
async def leggi(bot, update, arguments): async def leggi(bot, update, arguments):
@ -66,16 +78,26 @@ Sintassi: `/leggi <random | numerofrase>`"""
if len(arguments) == 0 or len(arguments) > 1: if len(arguments) == 0 or len(arguments) > 1:
await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/leggi <random | numerofrase>`", parse_mode="Markdown") await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/leggi <random | numerofrase>`", parse_mode="Markdown")
return return
# Open the file
file = open("diario.txt", "r") file = open("diario.txt", "r")
# Split the data in lines
entries = file.read().split("\n") entries = file.read().split("\n")
file.close() file.close()
# Choose an entry
if arguments[0] == "random": if arguments[0] == "random":
# either randomly...
entry_number = random.randrange(len(entries)) entry_number = random.randrange(len(entries))
else: else:
# ...or a specific one
entry_number = arguments[0] entry_number = arguments[0]
# Split the timestamp from the text
entry = entries[entry_number].split("|", 1) entry = entries[entry_number].split("|", 1)
# Parse the timestamp
date = datetime.datetime.fromtimestamp(entry[0]).isoformat() date = datetime.datetime.fromtimestamp(entry[0]).isoformat()
# Get the text
text = entry[1] text = entry[1]
# Sanitize the text to prevent TelegramErrors
text = text.replace("_", "\_").replace("*", "\*").replace("`", "\`").replace("[", "\[")
await update.message.reply(bot, f"Frase #{entry_number} | {date}\n{text}", parse_mode="Markdown") await update.message.reply(bot, f"Frase #{entry_number} | {date}\n{text}", parse_mode="Markdown")
@ -110,6 +132,8 @@ Sintassi: `/markov [inizio]`"""
await update.message.reply(bot, f"⚠ Non sono state trovate corrispondenze nel diario dell'inizio che hai specificato.", parse_mode="Markdown") await update.message.reply(bot, f"⚠ Non sono state trovate corrispondenze nel diario dell'inizio che hai specificato.", parse_mode="Markdown")
return return
if text is not None: if text is not None:
# Sanitize the text to prevent TelegramErrors
text = text.replace("_", "\_").replace("*", "\*").replace("`", "\`").replace("[", "\[")
await update.message.reply(bot, f"*Frase generata:*\n{text}", parse_mode="Markdown") await update.message.reply(bot, f"*Frase generata:*\n{text}", parse_mode="Markdown")
else: else:
await update.message.reply(bot, f"⚠ Il bot non è riuscito a generare una nuova frase.\nSe è la prima volta che vedi questo errore, riprova, altrimenti prova a cambiare configurazione.") await update.message.reply(bot, f"⚠ Il bot non è riuscito a generare una nuova frase.\nSe è la prima volta che vedi questo errore, riprova, altrimenti prova a cambiare configurazione.")
@ -127,25 +151,41 @@ Sintassi: `/help [comando]`"""
if arguments[0] in b.commands: if arguments[0] in b.commands:
await update.message.reply(bot, b.commands[arguments[0]].__doc__, parse_mode="Markdown") await update.message.reply(bot, b.commands[arguments[0]].__doc__, parse_mode="Markdown")
else: else:
await update.message.reply(bot, "⚠ Il comando specificato non esiste.", parse_mode="Markdown") await update.message.reply(bot, "⚠ Il comando specificato non esiste.")
async def discord(bot, update, arguments): async def discord(bot, update, arguments):
"""Manda un messaggio a #chat di Discord. """Manda un messaggio a #chat di Discord.
Sintassi: `/discord <messaggio>`""" Sintassi: `/discord <messaggio>`"""
# TODO: create a discord module # Try to login
# Send a message through a Discord webhook logged_user = currently_logged_in(update)
# Message to send # Check if the user is logged in
if not logged_user:
await update.message.reply(bot, "⚠ Non hai ancora eseguito l'accesso! Usa `/sync`.", parse_mode="Markdown")
return
# Check if the currently logged in user is a Royal Games member
if not logged_user.royal:
await update.message.reply(bot, "⚠ Non sei autorizzato a eseguire questo comando.")
return
# Check the command syntax
if len(arguments) == 0: if len(arguments) == 0:
await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/discord <messaggio>`", parse_mode="Markdown") await update.message.reply(bot, "⚠ Sintassi del comando non valida.\n`/discord <messaggio>`", parse_mode="Markdown")
return return
username = str(update.message.sent_from)
message = " ".join(arguments) message = " ".join(arguments)
# Find the message sender's Discord username
users = list(d.client.get_all_members())
for user in users:
if user.id == logged_user.discord_id:
username = user.name
break
else:
# Use the telegram username
username = f"{update.message.sent_from}"
# Parameters to send # Parameters to send
params = { params = {
# TODO: show the message sender's Discord username "username": username,
"content": f"{username}: {message}" "content": f"{message}"
} }
# Headers to send # Headers to send
headers = { headers = {
@ -165,7 +205,7 @@ Sintassi: `/discord <messaggio>`"""
# TODO: handle Discord webhooks errors # TODO: handle Discord webhooks errors
raise Exception("Qualcosa è andato storto durante l'invio del messaggio a Discord.") raise Exception("Qualcosa è andato storto durante l'invio del messaggio a Discord.")
# Answer on Telegram # Answer on Telegram
await update.message.reply(bot, "Richiesta inviata.", parse_mode="Markdown") await update.message.reply(bot, "Richiesta inviata.", parse_mode="Markdown")
async def sync_telegram(bot, update, arguments): async def sync_telegram(bot, update, arguments):