Files
Polyboard/src/web.py
T

178 lines
4.8 KiB
Python
Raw Normal View History

2024-01-05 08:59:40 -07:00
import os
import src.utils as utils
import multiprocessing as mupr
from flask import Flask, render_template, Response
from flask import request, redirect, url_for, make_response
import src.jsonpack as jsonpack
2024-01-22 17:04:09 -07:00
import src.packets as packets
2024-01-05 08:59:40 -07:00
import src.auth as auth
webroot = utils.getRoot('html/')
app = Flask(__name__,
static_url_path=webroot,
static_folder=webroot,
template_folder=webroot)
class webtab():
def __init__(self):
self.name = None
self.pages = []
self.defaultPage = ''
self.html = ''
def recursiveAdder(self, objs):
html = ''
for obj in objs:
if isinstance(obj, webpagefolder):
html += '<details><summary>' +\
obj.name +\
'</summary><ul>\n' +\
self.recursiveAdder(obj.pages) +\
'</ul></details>\n'
else:
html += f'<li onclick=\'window.location="/{self.name}/{obj.name}"\'>' +\
obj.name +\
'</li>\n'
return html
def addHtml(self):
self.html = self.recursiveAdder(self.pages)
def addPage(self, page):
self.pages.append(page)
class webpagefolder():
def __init__(self):
self.name = None
self.pages = []
class webpage():
def __init__(self):
self.name = None
self.location = None
@app.route('/')
def index():
2024-01-22 17:04:09 -07:00
isValid = app.webserv.authServer.cookieLogin(request)
2024-01-05 08:59:40 -07:00
if not isValid:
return redirect("/login", code=302)
else:
2024-01-22 17:04:09 -07:00
return redirect(f'/{app.webserv.defaultTab}/{app.webserv.defaultPage}', code=302)
2024-01-05 08:59:40 -07:00
@app.route('/login')
def loginPage():
2024-01-22 17:04:09 -07:00
isValid = app.webserv.authServer.cookieLogin(request)
2024-01-05 08:59:40 -07:00
if isValid:
2024-01-22 17:04:09 -07:00
return redirect(f'/{app.webserv.defaultTab}/{app.webserv.defaultPage}', code=302)
2024-01-05 08:59:40 -07:00
return make_response(open(f'{webroot}nav.html', 'r').read()
.replace('<!--Place body here!!!-->', open(f'{webroot}login.html', 'r').read())
.replace('<!--Place tabs here!!!-->', '<a href="/login" role="button" class="outline topnav-button text-white">Login</a>')
2024-01-22 17:04:09 -07:00
.replace('<!--Place title here!!!-->', app.webserv.title)
2024-01-05 08:59:40 -07:00
.replace('<!--Place defaultPage here!!!-->', '/login'))
def recursivePageLocationFinder(pagename, objs):
returnVal = None
for obj in objs:
if isinstance(obj, webpagefolder):
tmp = recursivePageLocationFinder(pagename, obj.pages)
if tmp != None:
returnVal = tmp
else:
if obj.name == pagename:
returnVal = obj.location
return returnVal
@app.route('/<tabname>/<pagename>')
def page(tabname, pagename):
2024-01-22 17:04:09 -07:00
isValid = app.webserv.authServer.cookieLogin(request)
2024-01-05 08:59:40 -07:00
if not isValid:
return redirect("/login", code=302)
try:
2024-01-22 17:04:09 -07:00
tab = utils.getatribinarr(app.webserv.webtabs, 'name', tabname)
2024-01-05 08:59:40 -07:00
pageloc = recursivePageLocationFinder(pagename, tab.pages)
return make_response(open(utils.getRoot('html/nav.html'), 'r').read()
.replace('<!--Place body here!!!-->', open(utils.getRoot(pageloc), 'r').read())
2024-01-22 17:04:09 -07:00
.replace('<!--Place tabs here!!!-->', app.webserv.tabHtml)
2024-01-05 08:59:40 -07:00
.replace('<!--Place pages here!!!-->', tab.html)
2024-01-22 17:04:09 -07:00
.replace('<!--Place title here!!!-->', app.webserv.title)
.replace('<!--Place defaultPage here!!!-->', f'/{app.webserv.defaultTab}/{app.webserv.defaultPage}'))
2024-01-05 08:59:40 -07:00
except:
return redirect("/login", code=302)
@app.route('/src/<file>')
def src(file):
return app.send_static_file(f'src/{file}')
@app.errorhandler(404)
def err404(err):
return redirect("/", code=302)
2024-01-22 17:04:09 -07:00
2024-01-05 08:59:40 -07:00
class webserv():
def __init__(self):
self.title = 'Modulator'
self.port = 443
self.host = '0.0.0.0'
self.verbose = False
self.secure = True
self.tabHtml = ''
self.webtabs = []
self.defaultTab = 'main'
self.defaultPage = ''
self.app = None
2024-01-22 17:04:09 -07:00
def init(self):
2024-01-05 08:59:40 -07:00
if not self.verbose:
import logging
log = logging.getLogger('werkzeug')
log.setLevel(logging.ERROR)
if self.secure:
dataroot = utils.getRoot("data/")
sslcontext = (f'{dataroot}selfsign.crt', f'{dataroot}selfsign.key')
else:
sslcontext = None
def tabHtml(path, name):
return f'<a href="{path}" role="button" class="outline topnav-button text-white">{name}</a>'
for tab in self.webtabs:
self.tabHtml += tabHtml(f'/{tab.name}/{tab.defaultPage}', tab.name)
if tab.name == self.defaultTab:
self.defaultPage = tab.defaultPage
2024-01-22 17:04:09 -07:00
def testfunc1(ac, data):
print(ac)
print(data)
2024-01-05 08:59:40 -07:00
2024-01-22 17:04:09 -07:00
app.webserv = self
2024-01-05 08:59:40 -07:00
self.app = app
2024-01-22 17:04:09 -07:00
self.rawServer = packets.startRawListener(self)
self.authServer = auth.authServer(self)
self.proc = mupr.Process(target=app.run, kwargs=dict(debug=self.verbose, port=self.port, host=self.host, ssl_context=sslcontext))
def start(self):
2024-01-05 08:59:40 -07:00
self.proc.start()
2024-01-22 17:04:09 -07:00
# return self.rawServer
2024-01-05 08:59:40 -07:00
def stop(self):
self.proc.terminate()
# def sendfatal(self, err):
# self.rawServer.broadcast(jsonpack.pack({
# 'type': 'error',
# 'severity': 'fatal',
# 'error': err
# }))