changeset 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 6daa59d44ee2
children 08e0d1f8542c
files src/pages/merge-requests/new/page_meta.py src/pages/merge-requests/page_meta.py src/pages/merge-requests/view/page_meta.py
diffstat 3 files changed, 145 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /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"
--- /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}'))
--- /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_))