diff options
| author | Andrew <saintruler@gmail.com> | 2019-07-21 12:14:09 +0400 |
|---|---|---|
| committer | Andrew <saintruler@gmail.com> | 2019-07-21 12:14:09 +0400 |
| commit | 2305ced85888a23f86ecfcdfb64a3b69c4997a4c (patch) | |
| tree | 9d5cc4ad1c322ca2bf46b990498ad0a79d508aff /day9/task5_vue/backend/server.py | |
| parent | 8c8712f0e6b165f6967f5d2958f300df6182296c (diff) | |
Переписан бекенд. Добавлена валидация при обновлении значений в ряду.
Удалена предыдущая версия приложения без vue.
Diffstat (limited to 'day9/task5_vue/backend/server.py')
| -rw-r--r-- | day9/task5_vue/backend/server.py | 73 |
1 files changed, 0 insertions, 73 deletions
diff --git a/day9/task5_vue/backend/server.py b/day9/task5_vue/backend/server.py deleted file mode 100644 index 48d5946..0000000 --- a/day9/task5_vue/backend/server.py +++ /dev/null @@ -1,73 +0,0 @@ -from http.server import HTTPServer, BaseHTTPRequestHandler -from urllib.parse import parse_qs - -from backend.router import run -from backend.utils import parse_multipart_form - -import logging -import json - - -class MyHTTPRequestHandler(BaseHTTPRequestHandler): - def _set_response(self, code, content_type): - self.send_response(code) - self.send_header('Content-type', content_type) - self.end_headers() - - def do_GET(self): - try: - content_length = int(self.headers['Content-Length']) - get_data = parse_qs(self.rfile.read(content_length).decode('utf-8')) - except TypeError: - get_data = {} - - for key in get_data: - get_data[key] = get_data[key][0] - - self.finalize_request(run({ - 'url': self.path, - 'method': 'GET', - 'query': get_data - })) - - def do_POST(self): - content_length = int(self.headers['Content-Length']) - content_type = self.headers['Content-type'] - post_data = self.rfile.read(content_length) - - if content_type.split(';')[0] == 'multipart/form-data': - files = parse_multipart_form(post_data) - self.finalize_request(run({ - 'url': self.path, - 'method': 'POST', - 'query': {'files': files} - })) - - elif content_type.split(';')[0] in ['text/plain', 'application/x-www-form-urlencoded']: - post_data = parse_qs(post_data.decode('utf-8')) - for key in post_data: - post_data[key] = post_data[key][0] - - self.finalize_request(run({ - 'url': self.path, - 'method': 'POST', - 'query': post_data - })) - - elif content_type.split(';')[0] == 'application/json': - self.finalize_request(run({ - 'url': self.path, - 'method': 'POST', - 'query': json.loads(post_data.decode('utf-8')) - })) - - def finalize_request(self, response): - self._set_response(response.status_code, response.content_type) - self.wfile.write(response.content) - - -def start_server(host, port): - server_address = (host, port) - httpd = HTTPServer(server_address, MyHTTPRequestHandler) - logging.getLogger('tableApp').info(f'Server started on {host}:{port}') - httpd.serve_forever() |