Mercurial > libervia-backend
changeset 1419:be2df1ddea8e
plugins (groupblog, xep-0277) + tmp(rsm): improved style:
- removed external parenthesis in assertions
- added blank line after first line of docstrings
- replaced "__" prefixes by "_"
- renamed variabled named after the reserverd word "max" to "max_"
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 22 Apr 2015 18:30:28 +0200 (2015-04-22) |
parents | 6adf1b0be609 |
children | 7c0acb966fd6 |
files | src/plugins/plugin_misc_groupblog.py src/plugins/plugin_xep_0277.py src/tmp/wokkel/rsm.py |
diffstat | 3 files changed, 47 insertions(+), 38 deletions(-) [+] |
line wrap: on
line diff
--- a/src/plugins/plugin_misc_groupblog.py Mon Apr 20 16:46:17 2015 +0200 +++ b/src/plugins/plugin_misc_groupblog.py Wed Apr 22 18:30:28 2015 +0200 @@ -214,6 +214,7 @@ def _handleCommentsItems(self, items, service, node_identifier): """ Convert comments items to groupblog data, and send them as signals + @param items: comments items @param service: jid of the PubSub service used @param node_identifier: comments node @@ -261,12 +262,15 @@ def getNodeName(self, publisher): """Retrieve the name of publisher's node + @param publisher: publisher's jid - @return: node's name (string)""" + @return: node's name (string) + """ return NS_NODE_PREFIX + publisher.userhost() def _publishMblog(self, service, client, access_type, access_list, message, extra): """Actually publish the message on the group blog + @param service: jid of the item-access pubsub service @param client: SatXMPPClient of the publisher @param access_type: one of "PUBLIC", "GROUP", "JID" @@ -745,7 +749,7 @@ jids = self._getPublishersJIDs(publishers_type, publishers, client) node_ids = [self.getNodeName(publisher) for publisher in jids] d_list = yield self.host.plugins["XEP-0060"].subscribeToMany(client.item_access_pubsub, node_ids, profile_key=profile_key) - result = yield defer.DeferredList(d_list, consumeErrors=False) + yield defer.DeferredList(d_list, consumeErrors=False) defer.returnValue(None) def deleteAllGroupBlogsAndComments(self, profile_key=C.PROF_KEY_NONE):
--- a/src/plugins/plugin_xep_0277.py Mon Apr 20 16:46:17 2015 +0200 +++ b/src/plugins/plugin_xep_0277.py Wed Apr 22 18:30:28 2015 +0200 @@ -95,9 +95,9 @@ return (service, node) - def __removeXHTMLMarkups(self, xhtml): - """ - Remove XHTML markups from the given string. + def _removeXHTMLMarkups(self, xhtml): + """Remove XHTML markups from the given string. + @param xhtml: the XHTML string to be cleaned @return: a Deferred instance for the cleaned string """ @@ -142,17 +142,17 @@ for key in ['title', 'content']: # process the textual elements for attr_elt in xpath(entry_elt, key): - attr_content = self.__getLXMLInnerContent(attr_elt) + attr_content = self._getLXMLInnerContent(attr_elt) if not attr_content.strip(): continue # element with empty value content_type = attr_elt.get('type', 'text').lower() if content_type == 'xhtml': - text = self.__decapsulateExtraNS(attr_content) + text = self._decapsulateExtraNS(attr_content) microblog_data['%s_xhtml' % key] = yield self.host.plugins["TEXT-SYNTAXES"].clean_xhtml(text) else: microblog_data[key] = attr_content if key not in microblog_data and ('%s_xhtml' % key) in microblog_data: - microblog_data[key] = yield self.__removeXHTMLMarkups(microblog_data['%s_xhtml' % key]) + microblog_data[key] = yield self._removeXHTMLMarkups(microblog_data['%s_xhtml' % key]) try: # check for mandatory elements microblog_data['id'] = xpath(entry_elt, 'id')[0].text @@ -198,14 +198,14 @@ defer.returnValue(microblog_data) - def __getLXMLInnerContent(self, elt): + def _getLXMLInnerContent(self, elt): """Return the inner content of a lxml.etree.Element. It is not trivial because the lxml tostring method would return the full content including elt's tag and attributes, and elt.getchildren() would skip a text value which is not within an element...""" - return self.__getDomishInnerContent(ElementParser()(etree.tostring(elt))) + return self._getDomishInnerContent(ElementParser()(etree.tostring(elt))) - def __getDomishInnerContent(self, elt): + def _getDomishInnerContent(self, elt): """Return the inner content of a domish.Element.""" result = '' for child in elt.children: @@ -215,7 +215,7 @@ result += child # child is unicode return result - def __decapsulateExtraNS(self, text): + def _decapsulateExtraNS(self, text): """Check for XHTML namespace and decapsulate the content so the user who wants to modify an entry will see the text that he entered. Also this avoids successive encapsulation with a new <div>...</div> at @@ -223,7 +223,7 @@ elt = ElementParser()(text) if elt.uri != NS_XHTML: raise exceptions.DataError(_('Content of type XHTML must declare its namespace!')) - return self.__getDomishInnerContent(elt) + return self._getDomishInnerContent(elt) def microblogCB(self, itemsEvent, profile): """Callback to "MICROBLOG" PEP event.""" @@ -236,8 +236,10 @@ @defer.inlineCallbacks def data2entry(self, data, profile): """Convert a data dict to en entry usable to create an item + @param data: data dict as given by bridge method. - @return: deferred which fire domish.Element""" + @return: deferred which fire domish.Element + """ _uuid = unicode(uuid.uuid1()) _entry = atom.Entry() _entry.title = '' # reset the default value which is not empty @@ -266,7 +268,7 @@ setattr(_entry, key, elem) if not getattr(_entry, key).text: if hasattr(_entry, '%s_xhtml' % key): - text = yield self.__removeXHTMLMarkups(getattr(_entry, '%s_xhtml' % key).text) + text = yield self._removeXHTMLMarkups(getattr(_entry, '%s_xhtml' % key).text) setattr(_entry, key, text) if not _entry.title.text: # eventually move the data from content to title _entry.title = _entry.content.text @@ -298,6 +300,7 @@ @defer.inlineCallbacks def sendMicroblog(self, data, profile): """Send XEP-0277's microblog data + @param data: must include content @param profile: profile which send the mood""" if 'content' not in data: @@ -313,6 +316,7 @@ def getLastMicroblogs(self, pub_jid, max_items=10, profile_key=C.PROF_KEY_NONE): """Get the last published microblogs + @param pub_jid: jid of the publisher @param max_items: how many microblogs we want to get @param profile_key: profile key @@ -326,6 +330,7 @@ def setMicroblogAccess(self, access="presence", profile_key=C.PROF_KEY_NONE): """Create a microblog node on PEP with given access + If the node already exists, it change options @param access: Node access model, according to xep-0060 #4.5 @param profile_key: profile key"""
--- a/src/tmp/wokkel/rsm.py Mon Apr 20 16:46:17 2015 +0200 +++ b/src/tmp/wokkel/rsm.py Wed Apr 22 18:30:28 2015 +0200 @@ -36,8 +36,8 @@ """ A Result Set Management request. - @ivar max: limit on the number of retrieved items. - @itype max: C{int} or C{unicode} + @ivar max_: limit on the number of retrieved items. + @itype max_: C{int} or C{unicode} @ivar index: starting index of the requested page. @itype index: C{int} or C{unicode} @@ -49,30 +49,30 @@ @itype before: C{unicode} """ - max = 10 + max_ = 10 index = None after = None before = None - def __init__(self, max=None, index=None, after=None, before=None): - if max is not None: - max = int(max) - assert(max >= 0) - self.max = max + def __init__(self, max_=None, index=None, after=None, before=None): + if max_ is not None: + max_ = int(max_) + assert max_ >= 0 + self.max_ = max_ if index is not None: - assert(after is None and before is None) + assert after is None and before is None index = int(index) - assert(index >= 0) + assert index >= 0 self.index = index if after is not None: - assert(before is None) - assert(isinstance(after, unicode)) + assert before is None + assert isinstance(after, unicode) self.after = after if before is not None: - assert(isinstance(before, unicode)) + assert isinstance(before, unicode) self.before = before @classmethod @@ -99,8 +99,8 @@ elif elt.name in ('max', 'index'): setattr(request, elt.name, int(''.join(elt.children))) - if request.max is None: - raise RSMError("RSM request is missing its 'max' element") + if request.max_ is None: + raise RSMError("RSM request is missing its 'max_' element") return request @@ -111,7 +111,7 @@ @rtype: L{domish.Element} """ set_elt = domish.Element((NS_RSM, 'set')) - set_elt.addElement('max').addContent(unicode(self.max)) + set_elt.addElement('max').addContent(unicode(self.max_)) if self.index is not None: set_elt.addElement('index').addContent(unicode(self.index)) @@ -137,7 +137,7 @@ @rtype: L{domish.Element} """ if element.name == 'pubsub' and hasattr(element, 'items'): - element.items.attributes['max_items'] = unicode(self.max) + element.items.attributes['max_items'] = unicode(self.max_) set_elt = self.toElement() element.addChild(set_elt) @@ -169,18 +169,18 @@ def __init__(self, count=None, index=None, first=None, last=None): if count is not None: - assert(isinstance(count, int) and count >= 0) + assert isinstance(count, int) and count >= 0 self.count = count if index is not None: - assert(isinstance(index, int) and index >= 0) + assert isinstance(index, int) and index >= 0 self.index = index - assert(isinstance(first, unicode)) + assert isinstance(first, unicode) self.first = first - assert(isinstance(last, unicode)) + assert isinstance(last, unicode) self.last = last else: - assert(first is None and last is None) + assert first is None and last is None @classmethod def parse(cls, element): @@ -372,7 +372,7 @@ resource, request) set_elts = [elt for elt in result if elt.name == 'set'] if set_elts: - assert(len(set_elts) == 1) + assert len(set_elts) == 1 response.addChild(set_elts[0]) return response