1
Fork 0
mirror of https://github.com/RYGhub/royalnet.git synced 2024-11-23 19:44:20 +00:00

updated opendota module

This commit is contained in:
Steffo 2016-12-19 19:56:37 +01:00
parent b57d946e5b
commit 49c1fcbbdf
4 changed files with 613 additions and 16 deletions

562
herolist.json Normal file
View file

@ -0,0 +1,562 @@
[
{
"name": "antimage",
"id": 1,
"localized_name": "Anti-Mage"
},
{
"name": "axe",
"id": 2,
"localized_name": "Axe"
},
{
"name": "bane",
"id": 3,
"localized_name": "Bane"
},
{
"name": "bloodseeker",
"id": 4,
"localized_name": "Bloodseeker"
},
{
"name": "crystal_maiden",
"id": 5,
"localized_name": "Crystal Maiden"
},
{
"name": "drow_ranger",
"id": 6,
"localized_name": "Drow Ranger"
},
{
"name": "earthshaker",
"id": 7,
"localized_name": "Earthshaker"
},
{
"name": "juggernaut",
"id": 8,
"localized_name": "Juggernaut"
},
{
"name": "mirana",
"id": 9,
"localized_name": "Mirana"
},
{
"name": "nevermore",
"id": 11,
"localized_name": "Shadow Fiend"
},
{
"name": "morphling",
"id": 10,
"localized_name": "Morphling"
},
{
"name": "phantom_lancer",
"id": 12,
"localized_name": "Phantom Lancer"
},
{
"name": "puck",
"id": 13,
"localized_name": "Puck"
},
{
"name": "pudge",
"id": 14,
"localized_name": "Pudge"
},
{
"name": "razor",
"id": 15,
"localized_name": "Razor"
},
{
"name": "sand_king",
"id": 16,
"localized_name": "Sand King"
},
{
"name": "storm_spirit",
"id": 17,
"localized_name": "Storm Spirit"
},
{
"name": "sven",
"id": 18,
"localized_name": "Sven"
},
{
"name": "tiny",
"id": 19,
"localized_name": "Tiny"
},
{
"name": "vengefulspirit",
"id": 20,
"localized_name": "Vengeful Spirit"
},
{
"name": "windrunner",
"id": 21,
"localized_name": "Windranger"
},
{
"name": "zuus",
"id": 22,
"localized_name": "Zeus"
},
{
"name": "kunkka",
"id": 23,
"localized_name": "Kunkka"
},
{
"name": "lina",
"id": 25,
"localized_name": "Lina"
},
{
"name": "lich",
"id": 31,
"localized_name": "Lich"
},
{
"name": "lion",
"id": 26,
"localized_name": "Lion"
},
{
"name": "shadow_shaman",
"id": 27,
"localized_name": "Shadow Shaman"
},
{
"name": "slardar",
"id": 28,
"localized_name": "Slardar"
},
{
"name": "tidehunter",
"id": 29,
"localized_name": "Tidehunter"
},
{
"name": "witch_doctor",
"id": 30,
"localized_name": "Witch Doctor"
},
{
"name": "riki",
"id": 32,
"localized_name": "Riki"
},
{
"name": "enigma",
"id": 33,
"localized_name": "Enigma"
},
{
"name": "tinker",
"id": 34,
"localized_name": "Tinker"
},
{
"name": "sniper",
"id": 35,
"localized_name": "Sniper"
},
{
"name": "necrolyte",
"id": 36,
"localized_name": "Necrophos"
},
{
"name": "warlock",
"id": 37,
"localized_name": "Warlock"
},
{
"name": "beastmaster",
"id": 38,
"localized_name": "Beastmaster"
},
{
"name": "queenofpain",
"id": 39,
"localized_name": "Queen of Pain"
},
{
"name": "venomancer",
"id": 40,
"localized_name": "Venomancer"
},
{
"name": "faceless_void",
"id": 41,
"localized_name": "Faceless Void"
},
{
"name": "skeleton_king",
"id": 42,
"localized_name": "Skeleton King"
},
{
"name": "death_prophet",
"id": 43,
"localized_name": "Death Prophet"
},
{
"name": "phantom_assassin",
"id": 44,
"localized_name": "Phantom Assassin"
},
{
"name": "pugna",
"id": 45,
"localized_name": "Pugna"
},
{
"name": "templar_assassin",
"id": 46,
"localized_name": "Templar Assassin"
},
{
"name": "viper",
"id": 47,
"localized_name": "Viper"
},
{
"name": "luna",
"id": 48,
"localized_name": "Luna"
},
{
"name": "dragon_knight",
"id": 49,
"localized_name": "Dragon Knight"
},
{
"name": "dazzle",
"id": 50,
"localized_name": "Dazzle"
},
{
"name": "rattletrap",
"id": 51,
"localized_name": "Clockwerk"
},
{
"name": "leshrac",
"id": 52,
"localized_name": "Leshrac"
},
{
"name": "furion",
"id": 53,
"localized_name": "Nature's Prophet"
},
{
"name": "life_stealer",
"id": 54,
"localized_name": "Lifestealer"
},
{
"name": "dark_seer",
"id": 55,
"localized_name": "Dark Seer"
},
{
"name": "clinkz",
"id": 56,
"localized_name": "Clinkz"
},
{
"name": "omniknight",
"id": 57,
"localized_name": "Omniknight"
},
{
"name": "enchantress",
"id": 58,
"localized_name": "Enchantress"
},
{
"name": "huskar",
"id": 59,
"localized_name": "Huskar"
},
{
"name": "night_stalker",
"id": 60,
"localized_name": "Night Stalker"
},
{
"name": "broodmother",
"id": 61,
"localized_name": "Broodmother"
},
{
"name": "bounty_hunter",
"id": 62,
"localized_name": "Bounty Hunter"
},
{
"name": "weaver",
"id": 63,
"localized_name": "Weaver"
},
{
"name": "jakiro",
"id": 64,
"localized_name": "Jakiro"
},
{
"name": "batrider",
"id": 65,
"localized_name": "Batrider"
},
{
"name": "chen",
"id": 66,
"localized_name": "Chen"
},
{
"name": "spectre",
"id": 67,
"localized_name": "Spectre"
},
{
"name": "doom_bringer",
"id": 69,
"localized_name": "Doom"
},
{
"name": "ancient_apparition",
"id": 68,
"localized_name": "Ancient Apparition"
},
{
"name": "ursa",
"id": 70,
"localized_name": "Ursa"
},
{
"name": "spirit_breaker",
"id": 71,
"localized_name": "Spirit Breaker"
},
{
"name": "gyrocopter",
"id": 72,
"localized_name": "Gyrocopter"
},
{
"name": "alchemist",
"id": 73,
"localized_name": "Alchemist"
},
{
"name": "invoker",
"id": 74,
"localized_name": "Invoker"
},
{
"name": "silencer",
"id": 75,
"localized_name": "Silencer"
},
{
"name": "obsidian_destroyer",
"id": 76,
"localized_name": "Outworld Devourer"
},
{
"name": "lycan",
"id": 77,
"localized_name": "Lycanthrope"
},
{
"name": "brewmaster",
"id": 78,
"localized_name": "Brewmaster"
},
{
"name": "shadow_demon",
"id": 79,
"localized_name": "Shadow Demon"
},
{
"name": "lone_druid",
"id": 80,
"localized_name": "Lone Druid"
},
{
"name": "chaos_knight",
"id": 81,
"localized_name": "Chaos Knight"
},
{
"name": "meepo",
"id": 82,
"localized_name": "Meepo"
},
{
"name": "treant",
"id": 83,
"localized_name": "Treant Protector"
},
{
"name": "ogre_magi",
"id": 84,
"localized_name": "Ogre Magi"
},
{
"name": "undying",
"id": 85,
"localized_name": "Undying"
},
{
"name": "rubick",
"id": 86,
"localized_name": "Rubick"
},
{
"name": "disruptor",
"id": 87,
"localized_name": "Disruptor"
},
{
"name": "nyx_assassin",
"id": 88,
"localized_name": "Nyx Assassin"
},
{
"name": "naga_siren",
"id": 89,
"localized_name": "Naga Siren"
},
{
"name": "keeper_of_the_light",
"id": 90,
"localized_name": "Keeper of the Light"
},
{
"name": "wisp",
"id": 91,
"localized_name": "Wisp"
},
{
"name": "visage",
"id": 92,
"localized_name": "Visage"
},
{
"name": "slark",
"id": 93,
"localized_name": "Slark"
},
{
"name": "medusa",
"id": 94,
"localized_name": "Medusa"
},
{
"name": "troll_warlord",
"id": 95,
"localized_name": "Troll Warlord"
},
{
"name": "centaur",
"id": 96,
"localized_name": "Centaur Warrunner"
},
{
"name": "magnataur",
"id": 97,
"localized_name": "Magnus"
},
{
"name": "shredder",
"id": 98,
"localized_name": "Timbersaw"
},
{
"name": "bristleback",
"id": 99,
"localized_name": "Bristleback"
},
{
"name": "tusk",
"id": 100,
"localized_name": "Tusk"
},
{
"name": "skywrath_mage",
"id": 101,
"localized_name": "Skywrath Mage"
},
{
"name": "abaddon",
"id": 102,
"localized_name": "Abaddon"
},
{
"name": "elder_titan",
"id": 103,
"localized_name": "Elder Titan"
},
{
"name": "legion_commander",
"id": 104,
"localized_name": "Legion Commander"
},
{
"name": "ember_spirit",
"id": 106,
"localized_name": "Ember Spirit"
},
{
"name": "earth_spirit",
"id": 107,
"localized_name": "Earth Spirit"
},
{
"name": "abyssal_underlord",
"id": 108,
"localized_name": "Abyssal Underlord"
},
{
"name": "terrorblade",
"id": 109,
"localized_name": "Terrorblade"
},
{
"name": "phoenix",
"id": 110,
"localized_name": "Phoenix"
},
{
"name": "techies",
"id": 105,
"localized_name": "Techies"
},
{
"name": "oracle",
"id": 111,
"localized_name": "Oracle"
},
{
"name": "winter_wyvern",
"id": 112,
"localized_name": "Winter Wyvern"
},
{
"name": "arc_warden",
"id": 113,
"localized_name": "Arc Warden"
}
]

50
main.py
View file

@ -3,12 +3,12 @@ import discord
import json import json
import opendota import opendota
import overwatch #import overwatch
import league #import league
import strings as s import strings as s
import telegram import telegram
import bs4 import bs4
import brawlhalla #import brawlhalla
loop = asyncio.get_event_loop() loop = asyncio.get_event_loop()
d_client = discord.Client() d_client = discord.Client()
@ -250,10 +250,30 @@ async def opendota_last_match(timeout):
old_last = 0 old_last = 0
last = r["match_id"] last = r["match_id"]
if last > old_last: if last > old_last:
# Get player team
# 0 if radiant
# 1 if dire
team = r["player_slot"] & 0b10000000 >> 7
# Get victory status
victory = (bool(team) == r["radiant_win"])
# Prepare format map
f = {
"k": r["kills"],
"d": r["deaths"],
"a": r["assists"],
"player": player,
"result": s.won if victory else s.lost,
"hero": opendota.get_hero_name(r["hero_id"])
}
# Send a message # Send a message
loop.create_task(send_event(s.dota_new_match, player=player, k=r["kills"], d=r["deaths"], a=r["assists"])) loop.create_task(send_event(s.dota_new_match, **f))
# Update database # Update database
db[player]["dota"]["lastmatch"] = last try:
db[player]["dota"]["lastmatch"] = last
except KeyError:
db[player]["dota"] = {
"lastmatch": last
}
f = open("db.json", "w") f = open("db.json", "w")
json.dump(db, f) json.dump(db, f)
f.close() f.close()
@ -287,20 +307,20 @@ async def send_event(eventmsg: str, player: str, **kwargs):
# Send the message # Send the message
loop.create_task(telegram.send_message(msg, -2141322)) loop.create_task(telegram.send_message(msg, -2141322))
loop.create_task(overwatch_status_change(600)) #loop.create_task(overwatch_status_change(600))
print("[Overwatch] Added level up check to the queue.") #print("[Overwatch] Added level up check to the queue.")
loop.create_task(league_rank_change(900)) #loop.create_task(league_rank_change(900))
print("[League] Added rank change check to the queue.") #print("[League] Added rank change check to the queue.")
loop.create_task(league_level_up(900)) #loop.create_task(league_level_up(900))
print("[League] Added level change check to the queue.") #print("[League] Added level change check to the queue.")
loop.create_task(brawlhalla_update_mmr(7200)) #loop.create_task(brawlhalla_update_mmr(7200))
print("[Brawlhalla] Added mmr change check to the queue.") #print("[Brawlhalla] Added mmr change check to the queue.")
#loop.create_task(opendota_last_match(600)) loop.create_task(opendota_last_match(600))
#print("[OpenDota] Added last match check to the queue.") print("[OpenDota] Added last match check to the queue.")
try: try:
loop.run_until_complete(d_client.start(token)) loop.run_until_complete(d_client.start(token))

View file

@ -1,5 +1,6 @@
import asyncio import asyncio
import requests import requests
import json
loop = asyncio.get_event_loop() loop = asyncio.get_event_loop()
async def get_latest_match(steamidtre: str): async def get_latest_match(steamidtre: str):
@ -11,3 +12,11 @@ async def get_latest_match(steamidtre: str):
return pj[0] return pj[0]
else: else:
raise Exception("OpenDota request error") raise Exception("OpenDota request error")
def get_hero_name(heroid: int):
j = open("herolist.json", "r")
herolist = json.loads(j.read())
for hero in herolist:
if hero["id"] == heroid:
return hero["localized_name"]
return None

View file

@ -42,4 +42,10 @@ league_level_up = "{player} è salito al livello **{level}** su _League of Legen
brawlhalla_new_mmr = "{player} è passato da {oldmmr} MMR a **{mmr}** MMR su _Brawlhalla_!" brawlhalla_new_mmr = "{player} è passato da {oldmmr} MMR a **{mmr}** MMR su _Brawlhalla_!"
# Dota: new match # Dota: new match
dota_new_match = "{player} ha finito una partita a _Dota 2_ con {k}/{d}/{a}!" dota_new_match = "{player} ha **{result}** a _Dota 2_ con {k}/{d}/{a}, giocando **{hero}**!"
# Win: past participle
won = "vinto"
# Lose: past participle
lost = "perso"