Mercurial > libervia-web
view libervia/pages/files/view/page_meta.py @ 1193:aee3d8fa679f
pages: fixed cached data when `url_cache` is used:
`request.template_data` and `request.data` where cached using a shallow copy,
causing trouble when a mutable object was used.
This has been fixed by using a deepcopy, which should not be a resource issue as
`request.data` and `request.template_data` should contain a few data in most
cases.
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 12 Jun 2019 20:05:45 +0200 |
parents | 29eb15062416 |
children | b2d067339de3 |
line wrap: on
line source
#!/usr/bin/env python2.7 # -*- coding: utf-8 -*- from libervia.server.constants import Const as C from sat.core.i18n import _ from twisted.internet import defer 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 = u"files_view" access = C.PAGES_ACCESS_PROFILE def parse_url(self, request): self.getPathArgs(request, ["service", "*path"], min_args=2, service="jid", path="") def cleanup(dummy, tmp_dir, dest_path): try: os.unlink(dest_path) except OSError: log.warning(_(u"Can't remove temporary file {path}").format(path=dest_path)) try: os.rmdir(tmp_dir) except OSError: log.warning(_(u"Can't remove temporary directory {path}").format(path=tmp_dir)) @defer.inlineCallbacks def render(self, request): data = self.getRData(request) profile = self.getProfile(request) service, path_elts = data[u"service"], data[u"path"] basename = path_elts[-1] dir_elts = path_elts[:-1] dir_path = u"/".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 = yield self.host.bridgeCall( "fileJingleRequest", service.full(), dest_path, basename, u"", u"", {u"path": dir_path}, profile, ) log.debug(u"file requested") yield ProgressHandler(self.host, progress_id, profile).register() log.debug(u"file downloaded") self.delegateToResource(request, static.File(dest_path))