Mercurial > libervia-web
view libervia/pages/files/view/page_meta.py @ 1513:ff95501abe74
server (websocket): don't crash when a force-close is failing
author | Goffi <goffi@goffi.org> |
---|---|
date | Mon, 22 May 2023 11:57:49 +0200 |
parents | 106bae41f5c8 |
children |
line wrap: on
line source
#!/usr/bin/env python3 from libervia.server.constants import Const as C from sat.core.i18n import _ from twisted.web import static from libervia.server.utils import ProgressHandler import tempfile import os import os.path from sat.core.log import getLogger log = getLogger(__name__) """files handling pages""" name = "files_view" access = C.PAGES_ACCESS_PROFILE def parse_url(self, request): self.get_path_args(request, ["service", "*path"], min_args=2, service="jid", path="") def cleanup(__, tmp_dir, dest_path): try: os.unlink(dest_path) except OSError: log.warning(_("Can't remove temporary file {path}").format(path=dest_path)) try: os.rmdir(tmp_dir) except OSError: log.warning(_("Can't remove temporary directory {path}").format(path=tmp_dir)) async def render(self, request): data = self.get_r_data(request) profile = self.get_profile(request) service, path_elts = data["service"], data["path"] basename = path_elts[-1] dir_elts = path_elts[:-1] dir_path = "/".join(dir_elts) tmp_dir = tempfile.mkdtemp() dest_path = os.path.join(tmp_dir, basename) request.notifyFinish().addCallback(cleanup, tmp_dir, dest_path) progress_id = await self.host.bridge_call( "file_jingle_request", service.full(), dest_path, basename, "", "", {"path": dir_path}, profile, ) log.debug("file requested") await ProgressHandler(self.host, progress_id, profile).register() log.debug("file downloaded") self.delegate_to_resource(request, static.File(dest_path))