-
Notifications
You must be signed in to change notification settings - Fork 0
/
charno.py
74 lines (61 loc) · 2.24 KB
/
charno.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import discord, asyncio, time
import commands, level, permission
import config, logging
client = discord.Client()
timer = 0
@client.event
@asyncio.coroutine
def on_ready():
logging.debug("-----------------")
logging.debug(client.user.name)
logging.debug(client.user.id)
logging.debug(client.user.display_name)
logging.debug("-----------------")
@client.event
@asyncio.coroutine
def on_message(message):
save()
if message.content is "save" and message.author.id is client.user.id:
level.save()
commands.save()
permission.save()
logging.debug("Saving...")
level.tick()
level.process_message(message=message)
if message.content.lower().startswith('!block') and permission.has_permission(message.author.id) == 0:
yield from commands.block(message=message, client=client)
elif message.content.lower().startswith('!unblock') and permission.has_permission(message.author.id) == 0:
yield from commands.unblock(message=message, client=client)
elif message.content.lower().startswith('!status'):
yield from level.status(message=message, client=client)
elif message.content.lower().startswith('!givexp') and permission.has_permission(message.author.id) <= 1:
yield from level.give_exp(message=message, client=client)
elif message.content.lower().startswith('!takexp') and permission.has_permission(message.author.id) <= 1:
yield from level.take_exp(message=message, client=client)
elif message.content.lower().startswith('!setxp') and permission.has_permission(message.author.id) <= 1:
yield from level.set_exp(message=message, client=client)
elif message.content.lower().startswith('!top') and permission.has_permission(message.author.id) <= 3:
yield from level.top(message=message, client=client)
def save():
global timer
if time.time() - timer > 3600:
level.save()
commands.save()
timer = time.time()
logging.debug("Saving...")
if __name__ == "__main__":
logging.basicConfig(filename=config.LOG_PATH, filemode='w', level=logging.DEBUG)
timer = time.time()
commands.load()
level.load()
permission.load()
loop = asyncio.get_event_loop()
try:
loop.run_until_complete(client.start(config.BOT_TOKEN))
except (KeyboardInterrupt, Exception):
loop.close()
client.logout()
running = False
finally:
level.save()
commands.save()