X-Git-Url: https://plomlompom.com/repos/berlin_corona.txt?a=blobdiff_plain;ds=sidebyside;f=plomtask%2Fhttp.py;h=8106d13c3c9f5c65b16dd1df12705543e183d46e;hb=ab5a23f86261ef74b00fd77ff198275bac6b82fd;hp=b6019ef0761b1dc3a86d3a12f395cd5b96f40c5c;hpb=e51477ebea9fb701d88de85088b2fda1247c73a2;p=plomtask diff --git a/plomtask/http.py b/plomtask/http.py index b6019ef..8106d13 100644 --- a/plomtask/http.py +++ b/plomtask/http.py @@ -22,24 +22,10 @@ class TaskHandler(BaseHTTPRequestHandler): """Handles single HTTP request.""" server: TaskServer - def send_html(self, html: str, code: int = 200): - """Send HTML as proper HTTP response.""" - self.send_response(code) - self.end_headers() - self.wfile.write(bytes(html, 'utf-8')) - - def send_msg(self, msg: str, code: int = 400): - """Send message in HTML formatting as HTTP response.""" - html = self.server.jinja.get_template('msg.html').render(msg=msg) - self.send_html(html, code) - def do_GET(self): """Handle any GET request.""" try: - conn = DatabaseConnection(self.server.db) - parsed_url = urlparse(self.path) - site = path_split(parsed_url.path)[1] - params = parse_qs(parsed_url.query) + conn, site, params = self._init_handling() if 'calendar' == site: html = self.do_GET_calendar(conn) elif 'day' == site: @@ -49,9 +35,9 @@ class TaskHandler(BaseHTTPRequestHandler): raise HandledException('Test!') conn.commit() conn.close() - self.send_html(html) + self._send_html(html) except HandledException as error: - self.send_msg(error) + self._send_msg(error) def do_GET_calendar(self, conn: DatabaseConnection): """Show Days.""" @@ -62,3 +48,49 @@ class TaskHandler(BaseHTTPRequestHandler): """Show single Day.""" day = Day.by_date(conn, date) return self.server.jinja.get_template('day.html').render(day=day) + + def do_POST(self): + """Handle any POST request.""" + try: + conn, site, params = self._init_handling() + length = int(self.headers['content-length']) + postvars = parse_qs(self.rfile.read(length).decode(), + keep_blank_values=1) + if 'day' == site: + date = params.get('date', ['2024-01-01'])[0] + self.do_POST_day(conn, date, postvars) + conn.commit() + conn.close() + self._redirect('/') + except HandledException as error: + self._send_msg(error) + + def do_POST_day(self, conn: DatabaseConnection, date: str, postvars: dict): + """Update or insert Day of date and fields defined in postvars.""" + comment = postvars['comment'][0] + day = Day.by_date(conn, date, create=True) + day.comment = comment + day.save(conn) + + def _init_handling(self): + conn = DatabaseConnection(self.server.db) + parsed_url = urlparse(self.path) + site = path_split(parsed_url.path)[1] + params = parse_qs(parsed_url.query) + return conn, site, params + + def _redirect(self, target: str): + self.send_response(302) + self.send_header('Location', target) + self.end_headers() + + def _send_html(self, html: str, code: int = 200): + """Send HTML as proper HTTP response.""" + self.send_response(code) + self.end_headers() + self.wfile.write(bytes(html, 'utf-8')) + + def _send_msg(self, msg: str, code: int = 400): + """Send message in HTML formatting as HTTP response.""" + html = self.server.jinja.get_template('msg.html').render(msg=msg) + self._send_html(html, code)