anonkun/anonkun.py

152 lines
3.5 KiB
Python
Raw Normal View History

2018-06-14 14:40:35 -04:00
#!/usr/bin/env python3
"""
Simple file host using Flask.
"""
import os
import time
from flask import Flask, session, request, abort, redirect, url_for, g, \
render_template
from flask_socketio import SocketIO, emit, join_room
2018-06-15 18:13:59 -04:00
from flask_paranoid import Paranoid
import MySQLdb
2018-06-14 14:40:35 -04:00
class ReverseProxied(object):
"""
Wrap the application in this middleware and configure the
front-end server to add these headers, to let you quietly bind
this to a URL other than / and to an HTTP scheme that is
different than what is used locally.
In nginx:
location /myprefix {
proxy_pass http://192.168.0.1:5001;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Scheme $scheme;
proxy_set_header X-Script-Name /myprefix;
}
:param app: the WSGI application
"""
def __init__(self, app):
self.app = app
def __call__(self, environ, start_response):
script_name = environ.get('HTTP_X_SCRIPT_NAME', '')
if script_name:
environ['SCRIPT_NAME'] = script_name
path_info = environ['PATH_INFO']
if path_info.startswith(script_name):
environ['PATH_INFO'] = path_info[len(script_name):]
scheme = environ.get('HTTP_X_SCHEME', '')
if scheme:
environ['wsgi.url_scheme'] = scheme
return self.app(environ, start_response)
app = Flask(__name__)
app.wsgi_app = ReverseProxied(app.wsgi_app)
app.config['MAX_CONTENT_LENGTH'] = 16 * 1024 * 1024
socketio = SocketIO(app)
2018-06-15 18:13:59 -04:00
paranoid = Paranoid(app)
paranoid.redirect_view = 'index'
def db_execute(*args, **kwargs):
"""
Opens a connection to the app's database and executes the SQL statements
passed to this function.
"""
passwd = app.config.get("DB_KEY")
with MySQLdb.connect(user="anonkun", passwd=passwd, db="anonkun") as cur:
cur.execute(*args, **kwargs)
return cur
def init():
"""
Initializes the application.
"""
# init secret key
if os.path.exists("secret_key"):
with open("secret_key", "rb") as file:
secret_key = file.read()
else:
secret_key = os.urandom(64)
with open("secret_key", "wb") as file:
file.write(secret_key)
app.secret_key = secret_key
# init db
with open("db_key", "r") as file:
passwd = file.read().strip() # TODO: encrypt this
app.config["DB_KEY"] = passwd
try:
db_execute("SELECT * FROM `users`").fetchone()
except MySQLdb.ProgrammingError: # database not initialized
with open("anonkun.sql", "r") as file:
commands = file.read().split(";")
for cmd in commands:
cmd = cmd.strip()
if not cmd:
continue
db_execute(cmd)
2018-06-14 14:40:35 -04:00
@socketio.on('joined', namespace="/chat")
def joined(data):
2018-06-14 14:40:35 -04:00
"""
Sent by clients when they enter a room.
"""
room = data["room"]
join_room(room)
2018-06-14 14:40:35 -04:00
@socketio.on('message', namespace="/chat")
2018-06-14 14:40:35 -04:00
def text(data):
"""
Sent by a client when the user entered a new message.
"""
room = data["room"]
message = data["message"]
name = data["name"]
date = int(time.time())
data["date"] = date
emit('message', data, room=room)
2018-06-14 14:40:35 -04:00
@app.template_filter("strftime")
def unix2string(unix):
"""
Converts a unix timestamp into a string.
"""
form = "%Y-%m-%d %H:%M:%S"
2018-06-14 14:40:35 -04:00
t = time.localtime(unix)
return time.strftime(form, t)
messages = [{"name":"Anonymous", "date":1528998539, "message":"lol"}, {"name":"Namefag", "date":1528998521, "message":"kek"}]
@app.route("/quest/<path:questName>")
def quest(questName):
"""
An arbituary quest page.
"""
return render_template('quest.html', questName=questName, messages=messages)
@app.route("/")
2018-06-14 14:40:35 -04:00
def index():
"""
The index page.
"""
return render_template("index.html")
2018-06-15 18:13:59 -04:00
init()
if __name__ == "__main__":
app.run(host='0.0.0.0', port=5050)