diff options
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/kvmd/server.py | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/kvmd/apps/kvmd/server.py b/kvmd/apps/kvmd/server.py index ae82015e..cfe0a2bc 100644 --- a/kvmd/apps/kvmd/server.py +++ b/kvmd/apps/kvmd/server.py @@ -36,6 +36,7 @@ from typing import Set from typing import Callable from typing import Optional +import aiohttp import aiohttp.web import setproctitle @@ -129,6 +130,13 @@ def _json_exception(err: Exception, status: int) -> aiohttp.web.Response: }, status=status) +async def _get_multipart_field(reader: aiohttp.MultipartReader, name: str) -> aiohttp.BodyPartReader: + field = await reader.next() + if not field or field.name != name: + raise ValidatorError("Missing %r field" % (name)) + return field + + _ATTR_EXPOSED = "exposed" _ATTR_EXPOSED_METHOD = "exposed_method" _ATTR_EXPOSED_PATH = "exposed_path" @@ -450,19 +458,15 @@ class Server: # pylint: disable=too-many-instance-attributes written = 0 try: async with self.__msd: - field = await reader.next() - if not field or field.name != "image_name": - raise ValidatorError("Missing 'image_name' field") - image_name = (await field.read()).decode("utf-8")[:256] + name_field = await _get_multipart_field(reader, "image_name") + image_name = (await name_field.read()).decode("utf-8")[:256] - field = await reader.next() - if not field or field.name != "image_data": - raise ValidatorError("Missing 'image_data' field") + data_field = await _get_multipart_field(reader, "image_data") logger.info("Writing image %r to mass-storage device ...", image_name) await self.__msd.write_image_info(image_name, False) while True: - chunk = await field.read_chunk(self.__msd.chunk_size) + chunk = await data_field.read_chunk(self.__msd.chunk_size) if not chunk: break written = await self.__msd.write_image_chunk(chunk) |