abgame/game.py

98 lines
2.7 KiB
Python
Raw Normal View History

2023-06-02 09:48:48 +02:00
#! /bin/python3
from random import choice
2023-06-02 12:31:55 +02:00
from flask import Flask, render_template, request
2023-06-02 10:24:06 +02:00
from configparser import ConfigParser
2023-06-02 12:31:55 +02:00
from datetime import datetime
import logging
import pytz
2023-06-02 10:24:06 +02:00
2023-06-02 09:48:48 +02:00
app = Flask(__name__,
static_url_path='',
static_folder='static',
template_folder='templates')
2023-06-02 10:24:06 +02:00
config = ConfigParser()
config.read('config.ini')
2023-06-02 12:39:57 +02:00
logging.basicConfig(encoding='utf-8', level=logging.INFO, format='%(message)s')
2023-06-02 12:31:55 +02:00
logger = logging.getLogger('waitress')
2023-06-02 20:41:01 +02:00
tz = pytz.timezone(config.get('main', 'timezone'))
2023-06-02 12:31:55 +02:00
@app.after_request
def log_the_request(response):
now = datetime.now(tz=tz)
2023-06-02 15:55:18 +02:00
if 'X-Forwarded-For' in request.headers:
remote_addr = request.headers['X-Forwarded-For']
else:
remote_addr = request.remote_addr
2023-06-02 12:31:55 +02:00
if not request.remote_user:
remote_user = "-"
else:
remote_user = request.remote_user
2023-06-02 15:25:02 +02:00
2023-06-02 12:31:55 +02:00
if not request.referrer:
referrer = "-"
else:
referrer = request.referrer
if request.full_path[-1] == '?':
full_path = request.full_path[:-1]
else:
full_path = request.full_path
2023-06-02 12:31:55 +02:00
log = {
2023-06-02 15:55:18 +02:00
'remote_addr': remote_addr,
2023-06-02 12:31:55 +02:00
'remote_user': remote_user,
'url': full_path,
2023-06-02 12:31:55 +02:00
'date': now.strftime("%d/%b/%Y:%H:%M:%S %z"),
'referrer': referrer,
'user_agent': request.user_agent.string,
'method': request.method,
'content_length': response.content_length,
'status_code': response.status_code
}
logfile = "{} - {} [{}] \"{} {}\" {} {} \"{}\" \"{}\"".format(log['remote_addr'], log['remote_user'], log['date'], log['method'], log['url'], log['status_code'], log['content_length'], log['referrer'], log['user_agent'])
logger.info(logfile)
return response
2023-06-02 10:24:06 +02:00
2023-06-02 09:48:48 +02:00
@app.route("/")
def hello():
2023-06-02 10:24:06 +02:00
title = config.get('main', 'title')
separator = config.get('main', 'separator')
separator_char = config.get('main', 'separator_char')
2023-06-02 10:11:06 +02:00
ablines = []
2023-06-02 09:48:48 +02:00
now = datetime.now(tz=tz)
epoch = now.timestamp()
2023-06-02 09:48:48 +02:00
lines = getContent()
2023-06-03 00:14:35 +02:00
while len(lines) < 2:
2023-06-03 00:36:57 +02:00
logger.error('Error reading content')
print(lines)
2023-06-03 00:14:35 +02:00
lines = getContent()
2023-06-02 09:48:48 +02:00
for line in lines:
2023-06-02 10:24:06 +02:00
ab = line.split(separator_char)
2023-06-02 10:11:06 +02:00
ablines.append(
{'A': str(ab[0]), 'B': str(ab[1])}
)
2023-06-02 09:48:48 +02:00
2023-06-02 15:55:18 +02:00
with open("ab.txt", "r") as f:
2023-06-02 15:25:02 +02:00
num_lines = sum(1 for _ in f)
return render_template('index.html', title=title, separator=separator, content=ablines, num_lines=num_lines, epoch=epoch)
2023-06-02 09:48:48 +02:00
def getContent():
2023-06-02 15:55:18 +02:00
lines = [a.strip() for a in open("ab.txt", "r").readlines()]
2023-06-02 09:48:48 +02:00
result = [choice(lines) for a in range(5)]
return result
if __name__ == "__main__":
from waitress import serve
serve(app, host='0.0.0.0', port=5000, ident='a/b game')