Mercurial > libervia-web
diff src/pages/merge-requests/view/page_meta.py @ 991:6ce9647011b3
pages(merge-requests): merge requests new, view and list pages implementations.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 01 Dec 2017 01:08:25 +0100 |
parents | |
children | b92b06f023cb |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/merge-requests/view/page_meta.py Fri Dec 01 01:08:25 2017 +0100 @@ -0,0 +1,73 @@ +#!/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 sat.tools.common import template_xmlui +from sat.tools.common import uri +from sat.tools.common import data_objects +from sat.core.log import getLogger +log = getLogger('pages/tickets/view') +"""ticket handling pages""" + +name = u"merge-requests_view" +access = C.PAGES_ACCESS_PUBLIC +template = u"merge-request/item.html" + + +def parse_url(self, request): + try: + item_id = self.nextPath(request) + except IndexError: + log.warning(_(u"no ticket id specified")) + self.pageError(request, C.HTTP_BAD_REQUEST) + + data = self.getRData(request) + data[u'ticket_id'] = item_id + +@defer.inlineCallbacks +def prepare_render(self, request): + data = self.getRData(request) + template_data = request.template_data + service, node, ticket_id = data.get(u'service', u''), data.get(u'node', u''), data[u'ticket_id'] + profile = self.getProfile(request) + + if profile is None: + profile = C.SERVICE_PROFILE + else: + template_data['profile'] = profile + + tickets, metadata, parsed_tickets = yield self.host.bridge.mergeRequestsGet(service.full() if service else u'', + node, + C.NO_LIMIT, + [ticket_id], + '', + {'parse': C.BOOL_TRUE}, + profile) + ticket = template_xmlui.create(self.host, tickets[0], ignore=['publisher', 'request_data', 'type']) + template_data[u'item'] = ticket + template_data['patches'] = parsed_tickets[0] + comments_uri = ticket.widgets['comments_uri'].value + if comments_uri: + uri_data = uri.parseXMPPUri(comments_uri) + template_data['comments_node'] = comments_node = uri_data['node'] + template_data['comments_service'] = comments_service = uri_data['path'] + comments = yield self.host.bridge.mbGet(comments_service, + comments_node, + C.NO_LIMIT, + [], + {}, + profile) + + template_data[u'comments'] = data_objects.BlogItems(comments) + template_data[u'login_url'] = self.getPageRedirectURL(request) + +@defer.inlineCallbacks +def on_data_post(self, request): + type_ = self.getPostedData(request, u'type') + if type_ == u'comment': + blog_page = self.getPageByName(u'blog') + yield blog_page.on_data_post(self, request) + else: + log.warning(_(u"Unhandled data type: {}").format(type_))