1
Fork 0
mirror of https://github.com/RYGhub/royalnet.git synced 2024-11-24 03:54:20 +00:00
royalnet/bot.py

672 lines
39 KiB
Python
Raw Normal View History

2015-10-07 08:49:14 +00:00
# -*- coding: utf-8 -*-
import json
2016-02-01 16:31:03 +00:00
import time
import filemanager
import telegram
import steam
2015-10-08 16:39:56 +00:00
import random
2015-11-16 21:55:47 +00:00
import osu
2015-12-20 19:05:13 +00:00
import hearthstone
import lol
2016-02-14 15:19:26 +00:00
2016-03-03 18:24:07 +00:00
# Check per la modalità votazione del bot, corrisponde al numero della chat in cui è attiva la votazione
# 0 per disattivare la votazione
class Votazione:
chat = int()
domanda = str()
# 0: non votato
# 1: sì
# 2: no
# 3: astenuto
voto = dict()
def __init__(self, question, askin):
self.domanda = question
self.chat = askin
for persona in royalgames:
self.voto[persona] = int()
def ask(self):
telegram.sendmessage(self.domanda, self.chat)
def register(self, utente, voto):
self.voto[utente] = voto
def showresults(self):
lista = str()
si = 0
no = 0
astenuti = 0
for persona in self.voto:
if self.voto[persona] == 0:
lista += chr(9898)
elif self.voto[persona] == 1:
si += 1
lista += chr(128309)
elif self.voto[persona] == 2:
no += 1
lista += chr(128308)
elif self.voto[persona] == 3:
astenuti += 1
lista += chr(9899)
lista += " @" + persona + "\n"
if not si and not no and not astenuti:
telegram.sendmessage(chr(9888) + " Nessuno ha ancora votato!", self.chat)
else:
telegram.sendmessage(self.domanda + "\n"
"*Risultati:*\n"
"Sì: " + str(si) + " (" + str(round(si / (si + no + astenuti) * 100, 2)) + "%)\n"
"No: " + str(no) + " (" + str(round(no / (si + no + astenuti) * 100, 2)) + "%)\n"
"Astenuti: " + str(astenuti) + "\n\n" + lista, self.chat)
2016-02-14 15:19:26 +00:00
# Votazione in corso
incorso = None
2015-11-13 17:15:27 +00:00
# Playlist di /rage, si riempie quando è vuota
2015-10-08 16:39:56 +00:00
rage = []
2016-01-14 18:37:37 +00:00
# TODO: Rimettere gli audio di Wololo
# wololo = []
2015-11-20 15:31:46 +00:00
audiolist = {
2016-02-14 15:19:26 +00:00
'madinuovo': 'BQADAgADMwIAAh8GgAFQaq1JNk1ZtwI',
'sallati': 'BQADAgADrAIAAh8GgAHTdcu8cG-LbAI',
'giummipersempre': 'BQADAgADEAIAAh8GgAE4O2578G1EagI',
'nonewallhack': 'BQADAgAD3wEAAh8GgAEUqoKiAaPP9wI',
'crystalmaiden': 'BQADAgADqwIAAh8GgAE62csQVNai8QI',
'apeggia': 'BQADAgAD6wEAAh8GgAGe6IDqRVSAhwI',
'johncena': 'BQADAgAD4AEAAh8GgAFRi-UD1VvyLwI',
'tre': 'BQADAgADEwIAAh8GgAE-iNm-4V6pZAI',
'cinqueanni': 'BQADAgADrgIAAh8GgAGKOIASQZevMwI',
'infilatevi': 'BQADAgAD5gEAAh8GgAFsphnhj_xOnAI',
'invidiosi': 'BQADAgADqAIAAh8GgAEDx7kiV1MdAwI',
'salitipo': 'BQADAgADqQIAAh8GgAHhGzfuq1LGXAI',
'mammadimari': 'BQADAgADpgIAAh8GgAFoIX9f88R-vAI',
'plug': 'BQADAgADrwIAAh8GgAGdfZO0w1wAAYYC',
'spari': 'BQADAgADEQIAAh8GgAHaG4P-MmuJKAI',
'bastagarf': 'BQADAgAD6QEAAh8GgAF0xIIbFxW6NQI',
'omiodio': 'BQADAgADMgIAAh8GgAFe9-lVwzdFzAI',
}
2016-02-03 09:39:58 +00:00
2016-02-01 16:31:03 +00:00
# Elenco di username dei membri della RYG
royalgames = json.loads(filemanager.readfile("db.json"))
2016-01-21 19:47:25 +00:00
2016-03-04 13:40:19 +00:00
# Stringa dove mettere l'elenco di champion di lol gratuiti
lolfreestring = str()
2015-11-23 16:18:08 +00:00
random.seed()
2016-01-14 18:37:37 +00:00
# Ciclo principale del bot
2015-10-04 17:48:45 +00:00
print("Bot avviato!")
2015-11-13 17:15:27 +00:00
while True:
2016-02-28 13:58:40 +00:00
try:
# Guarda il comando ricevuto.
msg = telegram.getupdates()
# Se il messaggio non è una notifica di servizio...
if 'text' in msg:
# Salvatelo in una stringa
text = msg['text']
# Guarda l'ID della chat in cui è stato inviato
sentin = msg['chat']['id']
# ID del messaggio ricevuto
source = msg['message_id']
# Nome da visualizzare nella console per capire chi accidenti è che invia messaggi strani
if 'username' in msg['from']:
# Salva l'username se esiste
username = msg['from']['username']
else:
# Altrimenti, salva l'userID
username = str(msg['from']['id'])
# Se sei un membro della Royal Games
if username.lower() in royalgames:
# Riconosci il comando.
# Viene usato startswith perchè il comando potrebbe anche essere inviato in forma /ciao@RoyalBot.
if text.startswith('/ahnonlosoio'):
print("@" + username + ": /ahnonlosoio")
# Rispondi con Ah, non lo so nemmeno io.
telegram.sendmessage("Ah, non lo so nemmeno io!", sentin, source)
2016-03-29 17:50:43 +00:00
elif text.startswith('/ciaostefanino'):
print("@" + username + ": /ciaostefanino")
# Rispondi salutando Stefanino.
telegram.sendmessage("Ciao Stefanino!!!", sentin, source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/ehoh'):
print("@" + username + ": /ehoh")
# Rispondi con Eh, oh. Sono cose che capitano.
telegram.sendmessage("Eh, oh. Sono cose che capitano.", sentin, source)
elif text.startswith('/playing'):
print("@" + username + ": /playing")
# Informa Telegram che il messaggio è stato ricevuto e visualizza Royal Bot sta scrivendo.
telegram.sendchataction(sentin)
cmd = text.split(" ")
# Se è stato specificato un AppID...
if len(cmd) >= 2:
n = steam.getnumberofcurrentplayers(cmd[1])
# Se viene ricevuta una risposta...
if n is None:
telegram.sendmessage(chr(9888) + " L'app specificata non esiste!", sentin, source)
else:
2016-03-03 18:24:07 +00:00
telegram.sendmessage(
'In questo momento, ' + str(n) + ' persone stanno giocando a [' + cmd[1] +
'](https://steamdb.info/app/' + cmd[1] + '/graphs/)', sentin, source)
2016-02-01 16:31:03 +00:00
else:
2016-02-28 13:58:40 +00:00
telegram.sendmessage(chr(9888) + ' Non hai specificato un AppID!\n'
'La sintassi corretta è /playing <AppID>.', sentin, source)
elif text.startswith('/saldi'):
print("@" + username + ": /saldi")
# Visualizza il link di isthereanydeal con i saldi di un gioco.
# Informa Telegram che il messaggio è stato ricevuto e visualizza Royal Bot sta scrivendo.
telegram.sendchataction(sentin)
cmd = text.split(" ", 1)
if len(cmd) == 2:
telegram.sendmessage(
'Visualizza le offerte di '
'[' + cmd[1] + '](https://isthereanydeal.com/#/search:' + cmd[1].replace(' ', '%20') +
";/scroll:%23gamelist).", sentin, source)
2016-01-28 17:55:42 +00:00
else:
2016-02-28 13:58:40 +00:00
telegram.sendmessage(chr(9888) +
" Non hai specificato un gioco!"
"[Visualizza tutte le offerte]"
"(https://isthereanydeal.com/#/search:.;/scroll:%23gamelist).",
sentin, source)
elif text.startswith('/audio'):
print("@" + username + ": /audio")
cmd = text.split(" ", 1)
if len(cmd) > 1:
if cmd[1] in audiolist:
sendme = audiolist[cmd[1]]
telegram.senddocument(sendme, sentin, source)
else:
sendme = chr(9888) + " L'audio richiesto non esiste!\n*Audio disponibili*:\n"
for audio in audiolist:
sendme += audio + "\n"
telegram.sendmessage(sendme, sentin, source)
else:
sendme = chr(9888) + " Per mandare un audio, scrivi `/audio nomeaudio`\n*Audio disponibili*:\n"
for audio in audiolist:
sendme += audio + "\n"
2016-03-03 13:56:45 +00:00
telegram.sendmessage(sendme, sentin, source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/sbam'):
print("@" + username + ": /sbam")
# Manda l'audio contenente gli sbam di tutti i membri Royal Games.
telegram.senddocument('BQADAgADBwMAAh8GgAGSsR4rwmk_LwI', sentin)
elif text.startswith('/osu'):
print("@" + username + ": /osu")
# Visualizza il punteggio più recente di osu!
# Informa Telegram che il messaggio è stato ricevuto.
telegram.sendchataction(sentin)
# Trova il nome utente specificato
cmd = text.split(' ', 1)
# Se è stato specificato un nome utente
if len(cmd) >= 2:
# Trova la modalità
# 0 = osu!
# 1 = osu!taiko
# 2 = osu!catch
# 3 = osu!mania
cmd = text.split(' ', 2)
# Se è stata specificata una modalità
if len(cmd) >= 3:
# Modalità specificata
mode = int(cmd[2])
else:
# Imposta la modalità a osu!
mode = 0
# Prova a mandare una richiesta ai server di osu per l'ultima canzone giocata
try:
r = osu.getuserrecent(cmd[1], mode)
# Se la funzione restituisce un errore, riferisci su Telegram l'errore e previeni il crash.
except NameError:
2016-03-03 18:24:07 +00:00
telegram.sendmessage(chr(9888) + " Errore nella richiesta ai server di Osu!", sentin,
source)
2016-02-28 13:58:40 +00:00
# Se tutto va bene, continua!
2016-02-01 16:31:03 +00:00
else:
2016-02-28 13:58:40 +00:00
# Se ci sono delle mod attive...
if "enabled_mods" in r:
mods = osu.listmods(r['enabled_mods'])
else:
mods = ""
# Specifica cosa vuole dire il grado F e il grado X
if r['rank'] == 'F':
r['rank'] = 'Failed'
elif r['rank'] == 'X':
r['rank'] = 'Unranked'
if mode == 0:
# Visualizza le informazioni relative alla modalità osu!
telegram.sendmessage("*osu!*\n"
"[Beatmap {0}](https://osu.ppy.sh/b/{0})\n"
"*{1}*\n"
"{2}\n"
"*Punti*: {3}\n"
"*Combo* x{4}\n"
"*300*: {5}\n"
"*100*: {6}\n"
"*50*: {7}\n"
"*Awesome*: {8}\n"
"*Good*: {9}\n"
"*Miss*: {10}"
.format(r['beatmap_id'],
r['rank'],
mods,
r['score'],
r['maxcombo'],
r['count300'],
r['count100'],
r['count50'],
r['countkatu'],
r['countgeki'],
r['countmiss']), sentin, source)
elif mode == 1:
# Visualizza le informazioni relative alla modalità osu!taiko
telegram.sendmessage("*osu!taiko*\n"
"[Beatmap {0}](https://osu.ppy.sh/b/{0})\n"
"*{1}*\n"
"{2}\n"
"*Punti*: {3}\n"
"*Combo* x{4}\n"
"*Great*: {5}\n"
"*Good*: {6}\n"
"_Large_ *Great*: {7}\n"
"_Large_ *Good*: {8}\n"
"*Miss*: {9}"
.format(r['beatmap_id'],
r['rank'],
mods,
r['score'],
r['maxcombo'],
r['count300'],
r['count100'],
r['countkatu'],
r['countgeki'],
r['countmiss']), sentin, source)
elif mode == 2:
2016-03-03 18:24:07 +00:00
# TODO: Cos'è successo qui?
2016-02-28 13:58:40 +00:00
# Visualizza le informazioni relative alla modalità osu!catch
telegram.sendmessage("*osu!catch*\n"
"[Beatmap " + r['beatmap_id'] + "](" + 'https://osu.ppy.sh/b/' + r[
'beatmap_id'] +
")\n*" + r['rank'] + "*\n" + mods +
"\n*Punti*: " + r['score'] + "\n"
"*Combo* x" + r['maxcombo'] + "\n"
2016-03-03 18:24:07 +00:00
"*Fruit*: " +
2016-02-28 13:58:40 +00:00
r['count300'] + "\n"
"*Droplet* _tick_: " + r['count100'] + "\n"
2016-03-03 18:24:07 +00:00
"*Droplet* _trail_: " +
2016-02-28 13:58:40 +00:00
r['count50'] + "\n"
"*Miss*: " + r['countmiss'], sentin, source)
elif mode == 3:
2016-03-03 18:24:07 +00:00
# TODO: Cos'è successo qui?
2016-02-28 13:58:40 +00:00
# Visualizza le informazioni relative alla modalità osu!mania
telegram.sendmessage("*osu!mania*\n" +
"[Beatmap " + r['beatmap_id'] + "](" + 'https://osu.ppy.sh/b/' + r[
'beatmap_id'] + ")\n*" + r['rank'] + "*\n" + mods +
"\n*Punti*: " + r['score'] + "\n"
"*Combo* x" + r['maxcombo'] + "\n"
2016-03-03 18:24:07 +00:00
"_Rainbow_ *300*: " +
2016-02-28 13:58:40 +00:00
r['countgeki'] + "\n"
"*300*: " + r['count300'] + "\n"
"*100*: " + r[
'count100'] + "\n"
"*200*: " + r['countkatu'] + "\n"
"*50*: " + r[
'count50'] + "\n"
"*Miss*: " + r['countmiss'], sentin, source)
else:
# TODO: Mettere a posto sto schifo.
2016-03-04 15:44:05 +00:00
if "osu" in royalgames[username.lower()]:
r = osu.getuserrecent(royalgames[username.lower()]['osu'], 0)
2016-02-28 13:58:40 +00:00
if "enabled_mods" in r:
mods = osu.listmods(r['enabled_mods'])
else:
mods = ""
2016-02-01 16:58:09 +00:00
telegram.sendmessage("*osu!*\n"
"[Beatmap {0}](https://osu.ppy.sh/b/{0})\n"
"*{1}*\n"
"{2}\n"
"*Punti*: {3}\n"
"*Combo* x{4}\n"
"*300*: {5}\n"
"*100*: {6}\n"
"*50*: {7}\n"
"*Awesome*: {8}\n"
"*Good*: {9}\n"
"*Miss*: {10}"
.format(r['beatmap_id'],
r['rank'],
2016-02-14 15:22:46 +00:00
mods,
r['score'],
r['maxcombo'],
r['count300'],
r['count100'],
r['count50'],
r['countkatu'],
r['countgeki'],
r['countmiss']), sentin, source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/roll'):
print("@" + username + ": /roll")
cmd = text.split(' ', 1)
# Se è stato specificato un numero
if len(cmd) >= 2:
# Controlla che sia convertibile in un intero.
try:
m = int(cmd[1])
except ValueError:
telegram.sendmessage(chr(9888) + " Il numero specificato non è un intero.", sentin, source)
2016-02-01 16:31:03 +00:00
else:
2016-02-28 13:58:40 +00:00
# Imposta il numero massimo a 100.
m = 100
# Prova a generare un numero casuale.
if m == 34261891881215712181524122318242223183627453833:
telegram.sendmessage("Numero casuale da 1 a _get rekt_:\n*@FrankRekt è scarso*", sentin, source)
2016-01-28 17:55:42 +00:00
else:
2016-02-28 13:58:40 +00:00
try:
n = random.randrange(m) + 1
except ValueError:
2016-03-03 18:24:07 +00:00
telegram.sendmessage(chr(9888) + " Il numero specificato non è maggiore o uguale a 0.",
2016-03-04 13:58:13 +00:00
sentin, source)
2016-02-28 13:58:40 +00:00
# Se tutto va bene visualizza il numero generato
else:
2016-03-03 18:24:07 +00:00
telegram.sendmessage("Numero casuale da 1 a " + str(m) + ":\n*" + str(n) + "*", sentin,
source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/automah'):
print("@" + username + ": /automah")
# Invia il messaggio.
2016-03-03 18:24:07 +00:00
telegram.sendmessage("Automaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa! Devi funzionare, cavolo!",
sentin,
2016-02-28 13:58:40 +00:00
source)
elif text.startswith('/hs'):
print("@" + username + ": /hs")
# Informa Telegram che il messaggio è stato ricevuto.
telegram.sendchataction(sentin)
2016-02-05 18:10:24 +00:00
cmd = text.split(" ", 1)
2016-02-28 13:58:40 +00:00
# Se è stata specificata una carta...
if len(cmd) >= 2:
# Controlla che la carta specificata esista.
try:
r = hearthstone.card(cmd[1])
# Se ci sono più carte, prendine una a caso!
r = r[random.randrange(len(r))]
except ValueError:
telegram.sendmessage(chr(9888) + " La carta specificata non esiste!", sentin, source)
# Se tutto va bene, elabora e visualizza le informazioni sulla carta.
else:
# Si trova nelle bustine
if 'howToGet' not in r:
if 'cardSet' in r:
r['howToGet'] = "Trovala in " + r['cardSet'] + "."
else:
r['howToGet'] = "Inottenibile."
# Nessuna classe
if 'playerClass' not in r:
r['playerClass'] = "Neutral"
# Nessun effetto
if 'text' not in r:
r['text'] = ""
# Converti l'HTML nella descrizione in Markdown. Circa.
r['text'] = r['text'].replace("<b>", "*")
r['text'] = r['text'].replace("</b>", "*")
r['text'] = r['text'].replace("<i>", "_")
r['text'] = r['text'].replace("</i>", "_")
# Togli il $, che indica che il numero di danni può essere modificato dallo Spell Damage
r['text'] = r['text'].replace("$", "")
# Nessuna rarità
if 'rarity' not in r:
r['rarity'] = "None"
# Nessuna descrizione
if 'flavor' not in r:
r['flavor'] = ""
# Testo principale
# Magie
if r['type'] == "Spell":
text = str("[" + r['name'] + "](" + r['img'] + ") "
"(" + r['rarity'] + ")\n" +
r['playerClass'] + "\n" +
str(r['cost']) + " mana\n" +
r['text'] + "\n" +
r['howToGet'] + "\n\n_" +
r['flavor'] + "_\n")
# Servitori
elif r['type'] == "Minion":
text = str("[" + r['name'] + "](" + r['img'] + ") "
"(" + r['rarity'] + ")\n" +
r['playerClass'] + "\n" +
str(r['cost']) + " mana\n" +
str(r['attack']) + " attacco\n" +
str(r['health']) + " salute\n" +
r['text'] + "\n" +
r['howToGet'] + "\n\n_" +
r['flavor'] + "_\n")
# Armi
elif r['type'] == "Weapon":
text = str("[" + r['name'] + "](" + r['img'] + ") "
"(" + r['rarity'] + ")\n" +
r['playerClass'] + "\n" +
str(r['cost']) + " mana\n" +
str(r['attack']) + " attacco\n" +
str(r['durability']) + " integrita'\n" +
r['text'] + "\n" +
r['howToGet'] + "\n\n_" +
r['flavor'] + "_\n")
# Potere Eroe
elif r['type'] == "Hero Power":
text = str("[" + r['name'] + "](" + r['img'] + ")\n" +
r['playerClass'] + "\n" +
str(r['cost']) + " mana\n" +
r['text'] + "\n")
# Eroe
elif r['type'] == "Hero":
text = str("[" + r['name'] + "](" + r['img'] + ")\n" +
"*Eroe*\n" +
str(r['health']) + " salute\n")
telegram.sendmessage(text, sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non hai specificato nessuna carta!\n"
"La sintassi corretta è _/hs nomecarta_ .", sentin, source)
2016-04-09 21:52:15 +00:00
elif text.startswith('/online') or text.startswith('/cv'):
2016-02-28 13:58:40 +00:00
# Elenco di tutte le persone online su Steam
print("@" + username + ": /online ")
# Informa Telegram che il messaggio è stato ricevuto.
telegram.sendchataction(sentin)
cmd = text.split(" ")
if len(cmd) >= 2:
if cmd[1].lower() == "help":
telegram.sendmessage(chr(128309) + " Online\n" +
chr(128308) + " In gioco | Occupato\n" +
chr(9899) + " Assente | Inattivo\n" +
chr(128310) + " Disponibile per scambiare\n" +
chr(128311) + " Disponibile per giocare", sentin, source)
else:
# Stringa utilizzata per ottenere informazioni su tutti gli utenti in una sola richiesta a steam
userids = str()
for membro in royalgames:
2016-03-04 15:42:26 +00:00
if "steam" in royalgames[membro]:
userids += str(royalgames[membro]["steam"]) + ','
2016-02-28 13:58:40 +00:00
tosend = "*Online ora:*\n"
r = steam.getplayersummaries(userids)
for player in r:
# In gioco
if 'gameextrainfo' in player:
tosend += chr(128308) + " _" + player['gameextrainfo'] + "_ |"
elif 'gameid' in player:
tosend += chr(128308) + " _" + player['gameid'] + "_ |"
# Online
elif player['personastate'] == 1:
tosend += chr(128309)
# Occupato
elif player['personastate'] == 2:
tosend += chr(128308)
# Assente o Inattivo
elif player['personastate'] == 3 or player['personastate'] == 4:
tosend += chr(9899)
# Disponibile per scambiare
elif player['personastate'] == 5:
tosend += chr(128310)
# Disponibile per giocare
elif player['personastate'] == 6:
tosend += chr(128311)
if player['personastate'] != 0:
tosend += " " + player['personaname'] + "\n"
2016-02-01 16:31:03 +00:00
else:
2016-02-28 13:58:40 +00:00
telegram.sendmessage(tosend, sentin, source)
elif text.startswith('/shrekt'):
# Manda l'audio So much to do, so much to see
print("@" + username + ": /shrekt ")
telegram.senddocument("BQADBAADsQADiBjiAqYN-EBXASyhAg", sentin)
elif text.startswith('/nuovavotazione'):
if username == "Steffo":
print("@" + username + ": /nuovavotazione ")
cmd = text.split(" ", 1)
incorso = Votazione(cmd[1], sentin)
else:
2016-03-03 18:24:07 +00:00
telegram.sendmessage(
chr(9888) + " Non hai i permessi necessari per creare una nuova votazione.",
sentin, source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/si'):
print("@" + username + ": /si ")
if incorso is not None:
if incorso.chat == sentin:
incorso.register(username.lower(), 1)
telegram.sendmessage("Votazione registrata!", sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non è in corso nessuna votazione!", sentin, source)
elif text.startswith('/no'):
print("@" + username + ": /no ")
if incorso is not None:
if incorso.chat == sentin:
incorso.register(username.lower(), 2)
telegram.sendmessage("Votazione registrata!", sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non è in corso nessuna votazione!", sentin, source)
elif text.startswith('/astieniti'):
print("@" + username + ": /astieniti ")
if incorso is not None:
if incorso.chat == sentin:
incorso.register(username.lower(), 3)
telegram.sendmessage("Votazione registrata!", sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non è in corso nessuna votazione!", sentin, source)
elif text.startswith('/domanda'):
print("@" + username + ": /domanda ")
if incorso is not None:
if incorso.chat == sentin:
incorso.ask()
else:
telegram.sendmessage(chr(9888) + " Non è in corso nessuna votazione!", sentin, source)
elif text.startswith('/risultati'):
print("@" + username + ": /risultati ")
if incorso is not None:
if incorso.chat == sentin:
incorso.showresults()
else:
telegram.sendmessage(chr(9888) + " Non è in corso nessuna votazione!", sentin, source)
elif text.startswith('/diario'):
# Aggiungi una riga al diario Royal Games
print("@" + username + ": /diario ")
cmd = text.split(" ", 1)
if len(cmd) > 1:
2016-03-07 11:37:55 +00:00
if cmd[1].isprintable():
cmd[1] = cmd[1].replace("\n", " ")
diario = filemanager.readfile("diario.txt")
diario += str(int(time.time())) + "|" + cmd[1] + "\n"
filemanager.writefile("diario.txt", diario)
telegram.sendmessage("Aggiunto al diario RYG.", sentin, source)
2016-03-03 18:24:07 +00:00
else:
telegram.sendmessage(chr(9888) + " Il messaggio non può essere scritto.\n"
2016-03-03 18:34:27 +00:00
"Prova a togliere le emoji o boh?", sentin, source)
2016-02-28 13:58:40 +00:00
else:
telegram.sendmessage(chr(9888) + " Non hai scritto niente sul diario!\n"
2016-03-03 18:24:07 +00:00
"Sintassi corretta: /diario _quello che vuoi scrivere_",
sentin, source)
2016-02-28 13:58:40 +00:00
elif text.startswith('/leggi'):
# Leggi dal diario Royal Games
print("@" + username + ": /leggi")
cmd = text.split(" ", 1)
2016-02-12 18:50:42 +00:00
diario = filemanager.readfile("diario.txt")
2016-02-28 13:58:40 +00:00
diario = diario.split('\n')
text = str()
# Se è incluso un numero dopo leggi, prendi quel numero di eventi più recenti.
if len(cmd) > 1:
if cmd[1].lower() == "tutto":
for n in range(len(diario), 1, -1):
riga = diario[len(diario) - n]
riga = riga.split("|", 1)
ora = time.gmtime(int(riga[0]))
text += "`" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + str(
ora.tm_year) + "`: `" + \
str(ora.tm_hour) + ":" + str(ora.tm_min) + "` " + riga[1] + "\n"
2016-02-28 13:58:40 +00:00
if int(cmd[1]) < len(diario):
# L'ultimo numero è escluso.
for n in range(int(cmd[1]) + 1, 1, -1):
riga = diario[len(diario) - n]
riga = riga.split("|", 1)
ora = time.gmtime(int(riga[0]))
2016-03-03 18:24:07 +00:00
text += "`" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + str(
2016-03-07 11:33:45 +00:00
ora.tm_year) + "`: `" + \
2016-02-28 13:58:40 +00:00
str(ora.tm_hour) + ":" + str(ora.tm_min) + "` " + riga[1] + "\n"
else:
telegram.sendmessage(chr(9888) + " Il numero massimo di stringhe visualizzabili è " +
str(len(diario) - 1), sentin, source)
# Altrimenti, prendi un evento a caso.
2016-02-12 18:50:42 +00:00
else:
2016-02-28 13:58:40 +00:00
riga = diario[random.randrange(0, len(diario))]
riga = riga.split("|", 1)
ora = time.gmtime(int(riga[0]))
text += "`" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + str(ora.tm_year) + "`: `" + \
str(ora.tm_hour) + ":" + str(ora.tm_min) + "` " + riga[1] + "\n"
telegram.sendmessage(text, sentin, source)
elif text.startswith('/lolfree'):
# Visualizza i campioni gratuiti di LoL di questa settimana
print("@" + username + ": /lolfree")
# Informa Telegram che il messaggio è stato ricevuto.
telegram.sendchataction(sentin)
ora = time.gmtime()
cmd = text.split(" ", 1)
if len(cmd) > 1:
2016-03-03 18:26:25 +00:00
refresh = cmd[1].startswith("refresh")
2016-02-14 15:19:26 +00:00
else:
refresh = False
2016-02-28 13:58:40 +00:00
# Controlla se i dati sono già stati scaricati.
if lolfreestring is None or refresh:
# Crea un nuovo set di dati.
print("Aggiornamento champ gratuiti di League of Legends...")
lolfreestring = "Champion gratuiti del `" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + \
str(ora.tm_year) + " " + str(ora.tm_hour) + ":" + str(ora.tm_min) + "`\n"
r = lol.getfreerotation()
for champion in r:
2016-03-04 18:17:05 +00:00
staticdata = lol.getchampionstaticdata(champion['id'])
2016-02-28 13:58:40 +00:00
lolfreestring += "*" + staticdata['name'] + "* " + staticdata['title'] + '\n'
print("Completato.")
telegram.sendmessage(lolfreestring, sentin, source)
2016-03-04 19:16:53 +00:00
elif text.startswith('/lolhistory'):
# Visualizza le tue partite recenti di LoL
print("@" + username + ": /lolhistory")
# Informa Telegram che il messaggio è stato ricevuto.
telegram.sendchataction(sentin)
sendme = "*Ultime 5 ranked giocate:*\n"
cmd = text.split(" ", 1)
if "lol" in royalgames[username.lower()]:
r = lol.getmatchlist(royalgames[username.lower()]['lol'])
2016-03-07 11:33:26 +00:00
if len(r['matches']) > 0:
for match in r['matches'][:5]:
2016-03-04 19:16:53 +00:00
sd = lol.getchampionstaticdata(match['champion'])
sendme += "`{0}` {1} ({2})\n".format(str(match['matchId']),
sd['name'],
match['lane'])
telegram.sendmessage(sendme, sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non hai mai giocato ranked.", sentin, source)
else:
telegram.sendmessage(chr(9888) + " Non hai un account di LoL nel database.", sentin, source)
2016-02-28 14:00:58 +00:00
elif text.startswith('/crash'):
# Crasha il bot. Mi sembra geniale.
if username == 'Steffo':
2016-02-28 14:01:36 +00:00
raise Exception("Ho appena fatto crashare tutto apposta. Sono un genio.")
2016-02-28 13:58:40 +00:00
else:
print("@" + username + " bloccato.")
2016-02-28 14:12:13 +00:00
except Exception as e:
2016-02-28 14:19:14 +00:00
telegram.sendmessage(chr(9762) + " *ERRORE CRITICO:\n*"
2016-03-04 15:42:26 +00:00
"{0}\n".format(repr(e)), -2141322)
2016-02-28 14:19:14 +00:00
print("ERRORE CRITICO:\n"
2016-03-01 10:14:02 +00:00
"{0}".format(repr(e)))