forked from kyabe2718/pyeeic2019bot
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
executable file
·66 lines (48 loc) · 1.99 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
#! /usr/bin/python3
import time
import schedule
import atexit
import signal
import subprocess
import sys
import datetime
import assignment_notify
dev_channel_name = "#8-dev_bot"
def main():
res = subprocess.check_output(['curl', 'inet-ip.info'])
print("global ip is ", res.decode('utf-8'))
import init
# スケジューラにタスクを登録
# 10分毎にassignment_notify_mgrを更新する
def update_assignment_list():
new_assignment = init.assignment_notify_mgr.updateAssignmentList()
init.bot.postMessage(dev_channel_name, "new assignment: " + str(new_assignment))
if len(new_assignment) != 0:
msg = "新しく課題が追加されたよ!\n"
msg += assignment_notify.parseAssignmentList(new_assignment)
init.bot.postMessage(dev_channel_name, msg)
schedule.every(10).minutes.do(update_assignment_list)
schedule.every().day.at("17:00").do(init.postTommorowAssignment)
schedule.every().saturday.at("12:00").do(init.postNextWeekAssignment)
def atExit():
print("atExit is called")
init.bot.postMessage(dev_channel_name, "正常終了!!\n" + str(datetime.datetime.now()))
print("send message and exit")
sys.exit()
atexit.register(atExit) # プログラム終了時に呼ばれる関数を登録
def handler(signum, frame):
print("handler is called")
init.bot.postMessage(dev_channel_name,
"signal handler signum: " + str(signum) + "\nnow time: " + str(datetime.datetime.now()))
print("send message and exit")
sys.exit()
signal.signal(signal.SIGTERM, handler)
signal.signal(signal.SIGINT, handler)
init.bot.postMessage(dev_channel_name,
"start.\nglobal ip is " + res.decode('utf-8') + "\nnow time: " + str(datetime.datetime.now()))
print("all initialized\n")
while True:
schedule.run_pending()
time.sleep(1)
if __name__ == "__main__":
main()