-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
98 lines (69 loc) · 2.65 KB
/
app.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
import os
import requests
from dotenv import load_dotenv
load_dotenv()
from flask import Flask, request, abort, render_template, make_response
from linebot.exceptions import (
InvalidSignatureError
)
from linebot.models import (
MessageEvent, TextMessage)
import line_event_handlers
import domain
app = Flask(__name__)
exchange_rate_message_handler = line_event_handlers.ExchangeRateEventHandler()
mops_message_handler = line_event_handlers.MopsEventHandler()
@app.route("/callback", methods=['POST'])
def callback():
# get X-Line-Signature header value
signature = request.headers['X-Line-Signature']
# get request body as text
body = request.get_data(as_text=True)
app.logger.info("Request body: " + body)
# handle webhook body
try:
line_event_handlers.webhook_handler.handle(body, signature)
except InvalidSignatureError:
abort(400)
return 'OK'
@line_event_handlers.webhook_handler.add(MessageEvent, message=TextMessage)
def handle_message(event):
message = event.message.text
commands = message.split(' ')
event.message.text = ' '.join(commands[1:])
command = commands[0].lower()
if command == 'er':
exchange_rate_message_handler.handle_event(event)
elif command == 'mi':
mops_message_handler.handle_event(event)
else:
line_event_handlers.reply_message(event.reply_token,
line_event_handlers.ExchangeRateEventHandler.help_message()
+ '\n\n'
+ line_event_handlers.MopsEventHandler.help_message())
@app.route('/')
def hello_world():
return 'hello world!'
@app.route('/mi/<material_info_id>')
def mi_detail(material_info_id):
try:
material_info = domain.MaterialInformation.objects.get(id=material_info_id)
return render_template('mi_detail.html', material_info=material_info)
except:
return render_template('404.html'), 404
# @app.errorhandler(404)
# def page_not_found(error):
# return render_template('404.html'), 404
if __name__ == '__main__':
app.run()
import atexit
from apscheduler.schedulers.background import BackgroundScheduler
def wakeup():
requests.get(os.getenv('WAKEUP_URL'))
scheduler = BackgroundScheduler()
scheduler.add_job(func=line_event_handlers.start_rate_schedule_task, trigger="interval", minutes=1)
scheduler.add_job(func=line_event_handlers.start_mops_schedule_task, trigger="interval", minutes=10)
scheduler.add_job(func=wakeup, trigger="interval", minutes=10)
scheduler.start()
# Shut down the scheduler when exiting the app
atexit.register(lambda: scheduler.shutdown())