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:
parent
6d5b306d93
commit
b4230c0ae6
253
maloja/server.py
253
maloja/server.py
@ -27,7 +27,7 @@ from doreah import auth
|
|||||||
# technical
|
# technical
|
||||||
#from importlib.machinery import SourceFileLoader
|
#from importlib.machinery import SourceFileLoader
|
||||||
import importlib
|
import importlib
|
||||||
import _thread
|
from threading import Thread
|
||||||
import sys
|
import sys
|
||||||
import signal
|
import signal
|
||||||
import os
|
import os
|
||||||
@ -39,6 +39,11 @@ from css_html_js_minify import html_minify, css_minify
|
|||||||
import urllib
|
import urllib
|
||||||
|
|
||||||
|
|
||||||
|
######
|
||||||
|
### TECHNICAL SETTINGS
|
||||||
|
#####
|
||||||
|
|
||||||
|
|
||||||
#settings.config(files=["settings/default.ini","settings/settings.ini"])
|
#settings.config(files=["settings/default.ini","settings/settings.ini"])
|
||||||
#settings.update("settings/default.ini","settings/settings.ini")
|
#settings.update("settings/default.ini","settings/settings.ini")
|
||||||
MAIN_PORT = settings.get_settings("WEB_PORT")
|
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")
|
STATICFOLDER = pkg_resources.resource_filename(__name__,"web/static")
|
||||||
|
|
||||||
webserver = Bottle()
|
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)
|
auth.authapi.mount(server=webserver)
|
||||||
|
|
||||||
from .apis import init_apis
|
from .apis import init_apis
|
||||||
@ -65,67 +169,7 @@ def deprecated_api_s(pth):
|
|||||||
def deprecated_api(pth):
|
def deprecated_api(pth):
|
||||||
redirect("/apis/mlj_1/" + pth + "?" + request.query_string,308)
|
redirect("/apis/mlj_1/" + pth + "?" + request.query_string,308)
|
||||||
|
|
||||||
|
def register_endpoints_web_static():
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
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)
|
|
||||||
|
|
||||||
|
|
||||||
@webserver.route("/image")
|
@webserver.route("/image")
|
||||||
def dynamic_image():
|
def dynamic_image():
|
||||||
@ -196,24 +240,12 @@ def static(name,ext):
|
|||||||
return response
|
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 register_endpoints_web_dynamic():
|
||||||
def static_html_public(name):
|
|
||||||
return static_html(name)
|
|
||||||
|
|
||||||
def static_html(name):
|
def static_html(name):
|
||||||
if name in aliases: redirect(aliases[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")
|
log("Generated page {name} in {time:.5f}s".format(name=name,time=clock.stop()),module="debug_performance")
|
||||||
return clean_html(res)
|
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
|
# Shortlinks
|
||||||
|
|
||||||
@ -254,16 +300,65 @@ def redirect_artist(artist):
|
|||||||
def redirect_track(artists,title):
|
def redirect_track(artists,title):
|
||||||
redirect("/track?title=" + title + "&" + "&".join("artist=" + artist for artist in artists.split("/")))
|
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
|
#set graceful shutdown
|
||||||
signal.signal(signal.SIGINT, graceful_exit)
|
signal.signal(signal.SIGINT, graceful_exit)
|
||||||
signal.signal(signal.SIGTERM, 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():
|
def run_server():
|
||||||
|
|
||||||
|
Thread(target=wait_for_db).start()
|
||||||
## start database
|
## start database
|
||||||
database.start_db()
|
|
||||||
|
|
||||||
log("Starting up Maloja server...")
|
log("Starting up Maloja server...")
|
||||||
|
|
||||||
@ -274,4 +369,6 @@ def run_server():
|
|||||||
log("Error. Is another Maloja process already running?")
|
log("Error. Is another Maloja process already running?")
|
||||||
raise
|
raise
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
run_server()
|
run_server()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user