# HG changeset patch # User Goffi # Date 1512086905 -3600 # Node ID 6ce9647011b3b1d336a325e300bc25966ef376a7 # Parent 6daa59d44ee287380f341cb792adf277efdcc639 pages(merge-requests): merge requests new, view and list pages implementations. diff -r 6daa59d44ee2 -r 6ce9647011b3 src/pages/merge-requests/new/page_meta.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/merge-requests/new/page_meta.py Fri Dec 01 01:08:25 2017 +0100 @@ -0,0 +1,11 @@ +#!/usr/bin/env python2.7 +# -*- coding: utf-8 -*- + +from libervia.server.constants import Const as C +from sat.core.log import getLogger +log = getLogger('pages/ticket') +"""ticket handling pages""" + +name = u'merge-requests_new' +access = C.PAGES_ACCESS_PUBLIC +template = u"merge-request/create.html" diff -r 6daa59d44ee2 -r 6ce9647011b3 src/pages/merge-requests/page_meta.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/merge-requests/page_meta.py Fri Dec 01 01:08:25 2017 +0100 @@ -0,0 +1,61 @@ +#!/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.words.protocols.jabber import jid +from sat.tools.common import template_xmlui +from sat.tools.common import data_objects +from sat.core.log import getLogger +log = getLogger('pages/ticket') +"""ticket handling pages""" + +name = u'merge-requests_list' +access = C.PAGES_ACCESS_PUBLIC +template = u"ticket/overview.html" + + +def parse_url(self, request): + # check the service and node to use + try: + service = self.nextPath(request) + node = self.nextPath(request) + except IndexError: + log.warning(_(u"missing service and node")) + self.pageError(request, C.HTTP_BAD_REQUEST) + + if not service or service == u'@': + service = u'' + + if service: + try: + service = jid.JID(service) + except Exception: + log.warning(_(u"bad service entered: {}").format(service)) + self.pageError(request, C.HTTP_BAD_REQUEST) + + if not node or node == u'@': + node = u'' + + + self.checkCache(request, C.CACHE_PUBSUB, service=service, node=node, short='merge-requests') + + data = self.getRData(request) + data['service'] = service + data['node'] = node + + template_data = request.template_data + template_data[u'url_tickets_list'] = self.getPageByName('merge-requests_list').getURL(service.full(), node or u'@') + template_data[u'url_tickets_new'] = self.getSubPageURL(request, 'merge-requests_new') + +@defer.inlineCallbacks +def prepare_render(self, request): + data = self.getRData(request) + template_data = request.template_data + service, node = data[u'service'], data[u'node'] + profile = self.getProfile(request) or C.SERVICE_PROFILE + + merge_requests = yield self.host.bridge.mergeRequestsGet(service.full() if service else u'', node, C.NO_LIMIT, [], '', {}, profile) + template_data[u'tickets'] = [template_xmlui.create(self.host, x) for x in merge_requests[0]] + template_data[u'on_ticket_click'] = data_objects.OnClick(url=self.getSubPageURL(request, 'merge-requests_view', '{item.id}')) diff -r 6daa59d44ee2 -r 6ce9647011b3 src/pages/merge-requests/view/page_meta.py --- /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_))