view src/pages/files/list/page_meta.py @ 1092:63ed5f6bd4eb

pages: new "getURLByPath" method in LiberviaPage, which is similar to getURLByNames, but which a more readable way to request a path with named pages.
author Goffi <goffi@goffi.org>
date Fri, 01 Jun 2018 12:58:20 +0200
parents 2dab7692eae7
children cdd389ef97bc
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 libervia.server import session_iface
from libervia.server import pages_tools
from sat.core.log import getLogger
from sat.tools.common import uri
import json
import os
log = getLogger('pages/files/list')
"""files handling pages"""

name = u'files_list'
access = C.PAGES_ACCESS_PROFILE
template = u"file/overview.html"

def parse_url(self, request):
    self.getPathArgs(request, ['service', '*path'], min_args=1, service='jid', path='')

@defer.inlineCallbacks
def prepare_render(self, request):
    data = self.getRData(request)
    thumb_limit = data.get('thumb_limit', 300)
    template_data = request.template_data
    service, path_elts = data[u'service'], data[u'path']
    path = u'/'.join(path_elts)
    profile = self.getProfile(request) or C.SERVICE_PROFILE

    files_data = yield self.host.bridgeCall('FISList', service.full(), path, {}, profile)
    for file_data in files_data:
        try:
            extra_raw = file_data[u'extra']
        except KeyError:
            pass
        else:
            file_data[u'extra'] = json.loads(extra_raw) if extra_raw else {}
        dir_path = path_elts + [file_data['name']]
        if file_data[u'type'] == C.FILE_TYPE_DIRECTORY:
            page = self
        elif file_data[u'type'] == C.FILE_TYPE_FILE:
            page = self.getPageByName('files_view')

            ## thumbnails ##
            try:
                thumbnails = file_data[u'extra']['thumbnails']
                if not thumbnails:
                    raise KeyError
            except KeyError:
                pass
            else:
                thumbnails.sort(key = lambda t: t['size'])
                thumb = thumbnails[0]
                for thumb_data in thumbnails:
                    if thumb_data['size'][0] > thumb_limit:
                        break
                    thumb = thumb_data
                if u'url' in thumb:
                    file_data['thumb_url'] = thumb['url']
                elif u'id' in thumb:
                    try:
                        thumb_path = yield self.host.bridgeCall('bobGetFile', service.full(), thumb[u'id'], profile)
                    except Exception as e:
                        log.warning(_(u"Can't retrieve thumbnail: {reason}").format(reason=e))
                    else:
                        filename = os.path.basename(thumb_path)
                        session_data = self.host.getSessionData(request, session_iface.ISATSession)
                        file_data['thumb_url'] = os.path.join(session_data.cache_dir, filename)
        else:
            raise ValueError(u'unexpected file type: {file_type}'.format(file_type=file_data[u'type']))
        file_data[u'url'] = page.getURL(service.full(), *dir_path)

        ## comments ##
        comments_url = file_data.get(u'comments_url')
        if comments_url:
            parsed_url = uri.parseXMPPUri(comments_url)
            comments_service = file_data[u'comments_service'] = parsed_url['path']
            comments_node = file_data[u'comments_node'] = parsed_url['node']
            try:
                comments_count = file_data[u'comments_count'] = int(file_data['comments_count'])
            except KeyError:
                comments_count = None
            if comments_count and data.get('retrieve_comments', False):
                file_data[u'comments'] = yield pages_tools.retrieveComments(self,
                                                                            comments_service,
                                                                            comments_node,
                                                                            profile=profile)

    template_data[u'files_data'] = files_data
    template_data[u'path'] = path
    if path_elts:
        template_data[u'parent_url'] = self.getURL(service.full(), *path_elts[:-1])