-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
101 lines (78 loc) · 2.89 KB
/
main.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# -*- coding: utf8 -*-
import gettext
import json
import locale
import logging
import sys
import pytz
from apscheduler.schedulers.asyncio import AsyncIOScheduler
import core
from sample.DiscordBot import DiscordBot
__appname__ = 'Scheduling Discord Bot'
__version__ = "0.1"
__author__ = "Vincent 'Doezer' AIRIAU"
def get_prompt():
prompt = "!"
try:
with open('config.json', mode='r+', encoding='utf-8') as f:
config = json.load(f)
try:
prompt = config["prompt"]
except KeyError:
config.update({"prompt": prompt})
f.seek(0)
f.write(json.dumps(config))
f.truncate()
prompt = config["prompt"]
except:
logging.debug("Prompt not found. Using default '{}'.".format(prompt))
logging.info('The prompt is {}.'.format(prompt))
return prompt
def set_locale():
try:
with open('config.json', mode='r+', encoding='utf-8') as f:
config = json.load(f)
language = config["language"]
locale.setlocale(locale.LC_ALL, language)
except:
locale.setlocale(locale.LC_ALL, '')
loc = locale.getlocale()
filename = "res/messages_%s.mo" % locale.getlocale()[0][0:2]
try:
logging.debug("Opening message file %s for locale %s", filename, loc[0])
trans = gettext.GNUTranslations(open(filename, "rb"))
except IOError:
logging.debug("Locale not found. Using default messages")
trans = gettext.NullTranslations()
trans.install()
def main():
logging.basicConfig(
level=logging.INFO,
stream=sys.stdout,
format="%(asctime)s,%(msecs)03d %(levelname)-5.5s [%(name)s] %(message)s <%(lineno)d>",
)
prompt = get_prompt()
set_locale()
cmd_list = {'^{}help$'.format(prompt): core.bot_help_embed,
'^{}(?:schedule)$'.format(prompt): core.schedule_post,
'^{}(?:language)'.format(prompt): core.language}
with open('config.json') as f:
config = json.load(f)
bot = DiscordBot(prompt)
for action in cmd_list:
bot.register_action(action, cmd_list[action])
# Here setup the scheduler with your own timezone
bot.scheduler = AsyncIOScheduler(timezone=pytz.timezone('Europe/Paris'))
bot.scheduler.start()
# Use this place (before the bot.run instruction) to manually scheduly any job you'd like
# Here is an example that schedules a print('Hello world!') each day at 14:23
# bot.scheduler.add_job(print,
# trigger='cron',
# args=['Hello world!'],
# day='*',
# hour='14',
# minute='23')
# logging.warning('######## SCHEDULING THE PERIODIC CHECK EVERY DAY AT 14:23 ########')
bot.run(config['token'])
if __name__ == '__main__':
main()