From 9c48e99648374acea2b0547f2a8474fcea84d076 Mon Sep 17 00:00:00 2001 From: Stefano Pigozzi Date: Sun, 28 Feb 2016 14:58:40 +0100 Subject: [PATCH] Proviamo a mettere try...? --- bot.py | 1009 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 506 insertions(+), 503 deletions(-) diff --git a/bot.py b/bot.py index 10d00e67..984bb2cb 100644 --- a/bot.py +++ b/bot.py @@ -175,120 +175,205 @@ random.seed() # Ciclo principale del bot print("Bot avviato!") while True: - # 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) - 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: - telegram.sendmessage('In questo momento, ' + str(n) + ' persone stanno giocando a [' + cmd[1] + - '](https://steamdb.info/app/' + cmd[1] + '/graphs/)', sentin, source) - else: - telegram.sendmessage(chr(9888) + ' Non hai specificato un AppID!\n' - 'La sintassi corretta è /playing .', 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) - else: - 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) - sendme = audiolist[cmd[1]] - telegram.senddocument(sendme, sentin) - 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: - telegram.sendmessage(chr(9888) + " Errore nella richiesta ai server di Osu!", sentin, source) - # Se tutto va bene, continua! - else: - # Se ci sono delle mod attive... - if "enabled_mods" in r: - mods = osu.listmods(r['enabled_mods']) + 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) + 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: - 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('In questo momento, ' + str(n) + ' persone stanno giocando a [' + cmd[1] + + '](https://steamdb.info/app/' + cmd[1] + '/graphs/)', sentin, source) + else: + telegram.sendmessage(chr(9888) + ' Non hai specificato un AppID!\n' + 'La sintassi corretta è /playing .', 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) + else: + 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) + sendme = audiolist[cmd[1]] + telegram.senddocument(sendme, sentin) + 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: + telegram.sendmessage(chr(9888) + " Errore nella richiesta ai server di Osu!", sentin, source) + # Se tutto va bene, continua! + else: + # 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: + # 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" + "*Fruit*: " + + r['count300'] + "\n" + "*Droplet* _tick_: " + r['count100'] + "\n" + "*Droplet* _trail_: " + + r['count50'] + "\n" + "*Miss*: " + r['countmiss'], sentin, source) + elif mode == 3: + # 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" + "_Rainbow_ *300*: " + + 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. + if username.lower() in osuplayers: + r = osu.getuserrecent(osuplayers[username.lower()], 0) + if "enabled_mods" in r: + mods = osu.listmods(r['enabled_mods']) + else: + mods = "" telegram.sendmessage("*osu!*\n" "[Beatmap {0}](https://osu.ppy.sh/b/{0})\n" "*{1}*\n" @@ -312,330 +397,236 @@ while True: 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: - # 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" - "*Fruit*: " + - r['count300'] + "\n" - "*Droplet* _tick_: " + r['count100'] + "\n" - "*Droplet* _trail_: " + - r['count50'] + "\n" - "*Miss*: " + r['countmiss'], sentin, source) - elif mode == 3: - # 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" - "_Rainbow_ *300*: " + - 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. - if username.lower() in osuplayers: - r = osu.getuserrecent(osuplayers[username.lower()], 0) - if "enabled_mods" in r: - mods = osu.listmods(r['enabled_mods']) + 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) + else: + # 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) + else: + try: + n = random.randrange(m) + 1 + except ValueError: + telegram.sendmessage(chr(9888) + " Il numero specificato non è maggiore o uguale a 0.", sentin, + source) + # Se tutto va bene visualizza il numero generato else: - mods = "" - 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 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) - else: - # 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) - else: - try: - n = random.randrange(m) + 1 - except ValueError: - telegram.sendmessage(chr(9888) + " Il numero specificato non è maggiore o uguale a 0.", sentin, - source) - # Se tutto va bene visualizza il numero generato - else: - telegram.sendmessage("Numero casuale da 1 a " + str(m) + ":\n*" + str(n) + "*", sentin, source) - elif text.startswith('/automah'): - print("@" + username + ": /automah") - # Invia il messaggio. - telegram.sendmessage("Automaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa! Devi funzionare, cavolo!", sentin, - source) - elif text.startswith('/hs'): - print("@" + username + ": /hs") - # Informa Telegram che il messaggio è stato ricevuto. - telegram.sendchataction(sentin) - cmd = text.split(" ", 1) - # 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("", "*") - r['text'] = r['text'].replace("", "*") - r['text'] = r['text'].replace("", "_") - r['text'] = r['text'].replace("", "_") - # 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) - elif text.startswith('/online'): - # 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 nome in rygsteamids: - userids += str(rygsteamids[nome]) + ',' - 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" - else: - 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('/restart'): - # Riavvia il bot - if username == "Steffo": - print("@" + username + ": /restart ") - telegram.sendmessage("Riavvio accettato.", sentin, source) - sys.exit(0) - else: - telegram.sendmessage(chr(9888) + " Non hai i permessi necessari per creare una nuova votazione.", - sentin, source) - elif text.startswith('/nuovavotazione'): - if username == "Steffo": - print("@" + username + ": /nuovavotazione ") + telegram.sendmessage("Numero casuale da 1 a " + str(m) + ":\n*" + str(n) + "*", sentin, source) + elif text.startswith('/automah'): + print("@" + username + ": /automah") + # Invia il messaggio. + telegram.sendmessage("Automaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa! Devi funzionare, cavolo!", sentin, + source) + elif text.startswith('/hs'): + print("@" + username + ": /hs") + # Informa Telegram che il messaggio è stato ricevuto. + telegram.sendchataction(sentin) cmd = text.split(" ", 1) - incorso = Votazione(cmd[1], sentin) - else: - telegram.sendmessage(chr(9888) + " Non hai i permessi necessari per creare una nuova votazione.", - sentin, source) - 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('/cv'): - # Visualizza l'elenco di persone nella chat di Mumble - print("@" + username + ": /cv ") - # Informa Telegram che il messaggio è stato ricevuto. - telegram.sendchataction(sentin) - r = mumbleboxes.getserverstatus("https://www.mumbleboxes.com/servers/5454/cvp.json").json() - tosend = "*Utenti online:*\n" - for u in r['root']['users']: - if not u['mute']: - if u['selfDeaf']: - tosend += chr(128263) + " " - elif u['selfMute']: - tosend += chr(128264) + " " + # 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: - tosend += chr(128266) + " " - tosend += u['name'] + "\n" - for ch in r['root']['channels']: - for u in ch['users']: + # 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("", "*") + r['text'] = r['text'].replace("", "*") + r['text'] = r['text'].replace("", "_") + r['text'] = r['text'].replace("", "_") + # 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) + elif text.startswith('/online'): + # 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 nome in rygsteamids: + userids += str(rygsteamids[nome]) + ',' + 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" + else: + 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('/restart'): + # Riavvia il bot + if username == "Steffo": + print("@" + username + ": /restart ") + telegram.sendmessage("Riavvio accettato.", sentin, source) + sys.exit(0) + else: + telegram.sendmessage(chr(9888) + " Non hai i permessi necessari per creare una nuova votazione.", + sentin, source) + elif text.startswith('/nuovavotazione'): + if username == "Steffo": + print("@" + username + ": /nuovavotazione ") + cmd = text.split(" ", 1) + incorso = Votazione(cmd[1], sentin) + else: + telegram.sendmessage(chr(9888) + " Non hai i permessi necessari per creare una nuova votazione.", + sentin, source) + 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('/cv'): + # Visualizza l'elenco di persone nella chat di Mumble + print("@" + username + ": /cv ") + # Informa Telegram che il messaggio è stato ricevuto. + telegram.sendchataction(sentin) + r = mumbleboxes.getserverstatus("https://www.mumbleboxes.com/servers/5454/cvp.json").json() + tosend = "*Utenti online:*\n" + for u in r['root']['users']: if not u['mute']: if u['selfDeaf']: tosend += chr(128263) + " " @@ -643,75 +634,87 @@ while True: tosend += chr(128264) + " " else: tosend += chr(128266) + " " - tosend += u['name'] + " | _" + ch['name'] + "_\n" - telegram.sendmessage(tosend, sentin, source) - elif text.startswith('/diario'): - # Aggiungi una riga al diario Royal Games - print("@" + username + ": /diario ") - cmd = text.split(" ", 1) - if len(cmd) > 1: - 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) - else: - telegram.sendmessage(chr(9888) + " Non hai scritto niente sul diario!\n" - "Sintassi corretta: /diario _quello che vuoi scrivere_", sentin, - source) - elif text.startswith('/leggi'): - # Leggi dal diario Royal Games - print("@" + username + ": /leggi") - cmd = text.split(" ", 1) - diario = filemanager.readfile("diario.txt") - diario = diario.split('\n') - text = str() - # Se è incluso un numero dopo leggi, prendi quel numero di eventi più recenti. - if len(cmd) > 1: - 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])) - text += "`" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + str(ora.tm_year) + "`: `" + \ - str(ora.tm_hour) + ":" + str(ora.tm_min) + "` " + riga[1] + "\n" + tosend += u['name'] + "\n" + for ch in r['root']['channels']: + for u in ch['users']: + if not u['mute']: + if u['selfDeaf']: + tosend += chr(128263) + " " + elif u['selfMute']: + tosend += chr(128264) + " " + else: + tosend += chr(128266) + " " + tosend += u['name'] + " | _" + ch['name'] + "_\n" + telegram.sendmessage(tosend, sentin, source) + elif text.startswith('/diario'): + # Aggiungi una riga al diario Royal Games + print("@" + username + ": /diario ") + cmd = text.split(" ", 1) + if len(cmd) > 1: + 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) else: - telegram.sendmessage(chr(9888) + " Il numero massimo di stringhe visualizzabili è " + - str(len(diario) - 1), sentin, source) - # Altrimenti, prendi un evento a caso. - else: - 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: - if cmd[1].startswith("refresh"): - refresh = True + telegram.sendmessage(chr(9888) + " Non hai scritto niente sul diario!\n" + "Sintassi corretta: /diario _quello che vuoi scrivere_", sentin, + source) + elif text.startswith('/leggi'): + # Leggi dal diario Royal Games + print("@" + username + ": /leggi") + cmd = text.split(" ", 1) + diario = filemanager.readfile("diario.txt") + diario = diario.split('\n') + text = str() + # Se è incluso un numero dopo leggi, prendi quel numero di eventi più recenti. + if len(cmd) > 1: + 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])) + text += "`" + str(ora.tm_mday) + "/" + str(ora.tm_mon) + "/" + str(ora.tm_year) + "`: `" + \ + 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. + else: + 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: + if cmd[1].startswith("refresh"): + refresh = True + else: + refresh = False else: refresh = False - else: - refresh = False - # 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: - staticdata = lol.getsinglestaticdata(champion['id']) - lolfreestring += "*" + staticdata['name'] + "* " + staticdata['title'] + '\n' - print("Completato.") - telegram.sendmessage(lolfreestring, sentin, source) - else: - print("@" + username + " bloccato.") + # 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: + staticdata = lol.getsinglestaticdata(champion['id']) + lolfreestring += "*" + staticdata['name'] + "* " + staticdata['title'] + '\n' + print("Completato.") + telegram.sendmessage(lolfreestring, sentin, source) + else: + print("@" + username + " bloccato.") + except Exception: + telegram.sendmessage(sys.exc_info(), -2141322)