1
0
mirror of https://github.com/krateng/maloja.git synced 2023-08-10 21:12:55 +03:00

Reorganized main loop and added temporary endpoints during DB build, GH-88

This commit is contained in:
krateng 2021-12-09 05:49:25 +01:00
parent 6d5b306d93
commit b4230c0ae6

View File

@ -27,7 +27,7 @@ from doreah import auth
# technical
#from importlib.machinery import SourceFileLoader
import importlib
import _thread
from threading import Thread
import sys
import signal
import os
@ -39,6 +39,11 @@ from css_html_js_minify import html_minify, css_minify
import urllib
######
### TECHNICAL SETTINGS
#####
#settings.config(files=["settings/default.ini","settings/settings.ini"])
#settings.update("settings/default.ini","settings/settings.ini")
MAIN_PORT = settings.get_settings("WEB_PORT")
@ -49,6 +54,105 @@ BaseRequest.MEMFILE_MAX = 15 * 1024 * 1024
STATICFOLDER = pkg_resources.resource_filename(__name__,"web/static")
webserver = Bottle()
#rename process, this is now required for the daemon manager to work
setproctitle.setproctitle("Maloja")
######
### CSS
#####
def generate_css():
css = ""
for f in os.listdir(os.path.join(STATICFOLDER,"css")):
with open(os.path.join(STATICFOLDER,"css",f),"r") as fd:
css += fd.read()
css = css_minify(css)
return css
css = generate_css()
######
### MINIFY
#####
def clean_html(inp):
if settings.get_settings("DEV_MODE"): return inp
else: return html_minify(inp)
######
### ERRORS
#####
@webserver.error(400)
@webserver.error(403)
@webserver.error(404)
@webserver.error(405)
@webserver.error(408)
@webserver.error(500)
@webserver.error(503)
@webserver.error(505)
def customerror(error):
errorcode = error.status_code
errordesc = error.status
traceback = error.traceback or error.body
traceback = traceback.strip() if traceback is not None else "No Traceback"
adminmode = request.cookies.get("adminmode") == "true" and auth.check(request)
template = jinja_environment.get_template('error.jinja')
return template.render(
errorcode=errorcode,
errordesc=errordesc,
traceback=traceback,
adminmode=adminmode,
)
######
### REGISTERING ENDPOINTS
#####
aliases = {
"admin": "admin_overview",
"manual": "admin_manual",
"setup": "admin_setup",
"issues": "admin_issues"
}
def register_endpoints_api():
auth.authapi.mount(server=webserver)
from .apis import init_apis
@ -65,67 +169,7 @@ def deprecated_api_s(pth):
def deprecated_api(pth):
redirect("/apis/mlj_1/" + pth + "?" + request.query_string,308)
def generate_css():
css = ""
for f in os.listdir(os.path.join(STATICFOLDER,"css")):
with open(os.path.join(STATICFOLDER,"css",f),"r") as fd:
css += fd.read()
css = css_minify(css)
return css
css = generate_css()
def clean_html(inp):
if settings.get_settings("DEV_MODE"): return inp
else: return html_minify(inp)
@webserver.route("")
@webserver.route("/")
def mainpage():
return static_html("start")
@webserver.error(400)
@webserver.error(403)
@webserver.error(404)
@webserver.error(405)
@webserver.error(408)
@webserver.error(500)
@webserver.error(505)
def customerror(error):
errorcode = error.status_code
errordesc = error.status
traceback = error.traceback
traceback = traceback.strip() if traceback is not None else "No Traceback"
adminmode = request.cookies.get("adminmode") == "true" and auth.check(request)
template = jinja_environment.get_template('error.jinja')
return template.render(
errorcode=errorcode,
errordesc=errordesc,
traceback=traceback,
adminmode=adminmode,
)
def graceful_exit(sig=None,frame=None):
#urllib.request.urlopen("http://[::1]:" + str(DATABASE_PORT) + "/sync")
log("Received signal to shutdown")
try:
database.sync()
except Exception as e:
log("Error while shutting down!",e)
log("Server shutting down...")
os._exit(42)
def register_endpoints_web_static():
@webserver.route("/image")
def dynamic_image():
@ -196,24 +240,12 @@ def static(name,ext):
return response
aliases = {
"admin": "admin_overview",
"manual": "admin_manual",
"setup": "admin_setup",
"issues": "admin_issues"
}
@webserver.route("/<name:re:admin.*>")
@auth.authenticated
def static_html_private(name):
return static_html(name)
@webserver.route("/<name>")
def static_html_public(name):
return static_html(name)
def register_endpoints_web_dynamic():
def static_html(name):
if name in aliases: redirect(aliases[name])
@ -244,6 +276,20 @@ def static_html(name):
log("Generated page {name} in {time:.5f}s".format(name=name,time=clock.stop()),module="debug_performance")
return clean_html(res)
@webserver.route("/<name:re:admin.*>")
@auth.authenticated
def static_html_private(name):
return static_html(name)
@webserver.route("/<name>")
def static_html_public(name):
return static_html(name)
@webserver.route("")
@webserver.route("/")
def mainpage():
return static_html("start")
# Shortlinks
@ -254,16 +300,65 @@ def redirect_artist(artist):
def redirect_track(artists,title):
redirect("/track?title=" + title + "&" + "&".join("artist=" + artist for artist in artists.split("/")))
######
### SHUTDOWN
#####
def graceful_exit(sig=None,frame=None):
#urllib.request.urlopen("http://[::1]:" + str(DATABASE_PORT) + "/sync")
log("Received signal to shutdown")
try:
database.sync()
except Exception as e:
log("Error while shutting down!",e)
log("Server shutting down...")
os._exit(42)
#set graceful shutdown
signal.signal(signal.SIGINT, graceful_exit)
signal.signal(signal.SIGTERM, graceful_exit)
#rename process, this is now required for the daemon manager to work
setproctitle.setproctitle("Maloja")
######
### RUNNING THE SERVER
#####
def register_temp_endpoint():
@webserver.route("/<path:path>")
@webserver.route("")
@webserver.route("/")
def notyet(*args,**kwargs):
abort(503,"Database is still being built")
def unregister_temp_endpoint():
pass
# TODO
def wait_for_db():
register_endpoints_web_static()
register_temp_endpoint()
database.start_db()
register_endpoints_api()
register_endpoints_web_dynamic()
unregister_temp_endpoint()
def run_server():
Thread(target=wait_for_db).start()
## start database
database.start_db()
log("Starting up Maloja server...")
@ -274,4 +369,6 @@ def run_server():
log("Error. Is another Maloja process already running?")
raise
run_server()