summaryrefslogtreecommitdiff
path: root/src/app.py
diff options
context:
space:
mode:
authoruser <user@node5.net>2024-07-19 23:32:40 +0200
committeruser <user@node5.net>2024-07-19 23:32:40 +0200
commit78e3f6ea427a10edaeac1c056f8a3ab5640e2a0c (patch)
tree0bd7a010f00fb07c15577e7fea9fb2128239b82f /src/app.py
Initial commit - displays events
Diffstat (limited to 'src/app.py')
-rw-r--r--src/app.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/src/app.py b/src/app.py
new file mode 100644
index 0000000..b063bec
--- /dev/null
+++ b/src/app.py
@@ -0,0 +1,69 @@
+import logging
+import os
+import datetime
+
+import flask
+import yaml
+
+import program_parser
+
+#import db_handler
+
+class CustomFormatter(logging.Formatter):
+ grey = "\x1b[90;20m"
+ blue = "\x1b[34;20m"
+ yellow = "\x1b[33;20m"
+ red = "\x1b[31;20m"
+ bold_red = "\x1b[31;1m"
+ reset = "\x1b[0m"
+ format = "%(asctime)s,%(msecs)03d %(levelname)-8s [%(filename)s:%(lineno)d] %(message)s"
+
+ FORMATS = {
+ logging.DEBUG: grey + format + reset,
+ logging.INFO: blue + format + reset,
+ logging.WARNING: yellow + format + reset,
+ logging.ERROR: red + format + reset,
+ logging.CRITICAL: bold_red + format + reset
+ }
+
+ def format(self, record):
+ log_fmt = self.FORMATS.get(record.levelno)
+ formatter = logging.Formatter(log_fmt)
+ return formatter.format(record)
+
+logger = logging.getLogger(__name__)
+if os.environ.get('FLASK_DEBUG') == '1': # Local development
+ logger.root.setLevel(logging.DEBUG)
+else: # Production
+ logger.root.setLevel(logging.INFO)
+
+stream_handler = logging.StreamHandler()
+stream_handler.setFormatter(CustomFormatter())
+logger.root.addHandler(stream_handler)
+
+app = flask.Flask(__name__, template_folder='templates', static_folder='static', static_url_path='')
+
+@app.route('/top')
+def top():
+ return f'BornHack S105 {datetime.datetime.now().strftime("%a %d %b %R:%S")} '
+
+@app.route('/program.json')
+def program():
+ events_to_show: list[Event] = program_parser.get_events_to_show(program_parser.program, programs_to_show_count = 16)
+ #{event.title} {day} {start_time}-{end_time} {icon}
+ json = [{'title': a.title, 'day': a.day, 'time': a.time, 'progress': a.progress, 'icon': a.icon} for a in events_to_show]
+ return json
+'''
+@app.route('/news')
+def news():
+ with open(news_file_path, "r") as news_file:
+ return news_file.read().replace('\n', '<br>')
+'''
+@app.route('/text')
+def text() -> dict[str, str]:
+ return {part: eval(part)() for part in ['top', 'program']}
+
+@app.route('/')
+def index():
+ return flask.render_template('index.html', parts=text())
+