summaryrefslogtreecommitdiff
path: root/src/home/media/node_server.py
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
committerEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
commitd3a295872c49defb55fc8e4e43e55550991e0927 (patch)
treeb9dca15454f9027d5a9dad0d4443a20de04dbc5d /src/home/media/node_server.py
parentb7cbc2571c1870b4582ead45277d0aa7f961bec8 (diff)
parentbdbb296697f55f4c3a07af43c9aaf7a9ea86f3d0 (diff)
Merge branch 'master' of ch1p.io:homekit
Diffstat (limited to 'src/home/media/node_server.py')
-rw-r--r--src/home/media/node_server.py86
1 files changed, 0 insertions, 86 deletions
diff --git a/src/home/media/node_server.py b/src/home/media/node_server.py
deleted file mode 100644
index 5d0803c..0000000
--- a/src/home/media/node_server.py
+++ /dev/null
@@ -1,86 +0,0 @@
-from .. import http
-from .record import Recorder
-from .types import RecordStatus
-from .storage import RecordStorage
-
-
-class MediaNodeServer(http.HTTPServer):
- recorder: Recorder
- storage: RecordStorage
-
- def __init__(self,
- recorder: Recorder,
- storage: RecordStorage,
- *args, **kwargs):
- super().__init__(*args, **kwargs)
-
- self.recorder = recorder
- self.storage = storage
-
- self.get('/record/', self.do_record)
- self.get('/record/info/{id}/', self.record_info)
- self.get('/record/forget/{id}/', self.record_forget)
- self.get('/record/download/{id}/', self.record_download)
-
- self.get('/storage/list/', self.storage_list)
- self.get('/storage/delete/', self.storage_delete)
- self.get('/storage/download/', self.storage_download)
-
- async def do_record(self, request: http.Request):
- duration = int(request.query['duration'])
- max = Recorder.get_max_record_time()*15
- if not 0 < duration <= max:
- raise ValueError(f'invalid duration: max duration is {max}')
-
- record_id = self.recorder.record(duration)
- return http.ok({'id': record_id})
-
- async def record_info(self, request: http.Request):
- record_id = int(request.match_info['id'])
- info = self.recorder.get_info(record_id)
- return http.ok(info.as_dict())
-
- async def record_forget(self, request: http.Request):
- record_id = int(request.match_info['id'])
-
- info = self.recorder.get_info(record_id)
- assert info.status in (RecordStatus.FINISHED, RecordStatus.ERROR), f"can't forget: record status is {info.status}"
-
- self.recorder.forget(record_id)
- return http.ok()
-
- async def record_download(self, request: http.Request):
- record_id = int(request.match_info['id'])
-
- info = self.recorder.get_info(record_id)
- assert info.status == RecordStatus.FINISHED, f"record status is {info.status}"
-
- return http.FileResponse(info.file.path)
-
- async def storage_list(self, request: http.Request):
- extended = 'extended' in request.query and int(request.query['extended']) == 1
-
- files = self.storage.getfiles(as_objects=extended)
- if extended:
- files = list(map(lambda file: file.__dict__(), files))
-
- return http.ok({
- 'files': files
- })
-
- async def storage_delete(self, request: http.Request):
- file_id = request.query['file_id']
- file = self.storage.find(file_id)
- if not file:
- raise ValueError(f'file {file} not found')
-
- self.storage.delete(file)
- return http.ok()
-
- async def storage_download(self, request):
- file_id = request.query['file_id']
- file = self.storage.find(file_id)
- if not file:
- raise ValueError(f'file {file} not found')
-
- return http.FileResponse(file.path)