Move security labels into own module

This commit is contained in:
Philipp Hörist 2018-07-21 13:19:01 +02:00
parent 78858f7c82
commit afb0306160
7 changed files with 112 additions and 72 deletions

View File

@ -207,19 +207,23 @@ class ChatControlBase(MessageControl, ChatCommandProcessor, CommandTools):
self.seclabel_combo.pack_start(cell, True) self.seclabel_combo.pack_start(cell, True)
# text to show is in in first column of liststore # text to show is in in first column of liststore
self.seclabel_combo.add_attribute(cell, 'text', 0) self.seclabel_combo.add_attribute(cell, 'text', 0)
if app.connections[self.account].seclabel_supported: con = app.connections[self.account]
app.connections[self.account].seclabel_catalogue(self.contact.jid, self.on_seclabels_ready) if con.get_module('SecLabels').supported:
con.get_module('SecLabels').request_catalog(self.contact.jid)
def on_seclabels_ready(self): def _sec_labels_received(self, event):
if event.account != self.account:
return
if event.jid != self.contact.jid:
return
lb = self.seclabel_combo.get_model() lb = self.seclabel_combo.get_model()
lb.clear() lb.clear()
i = 0 i = 0
sel = 0 sel = 0
catalogue = app.connections[self.account].seclabel_catalogues[ label_, labellist, default = event.catalog
self.contact.jid] for label in labellist:
for label in catalogue[2]:
lb.append([label]) lb.append([label])
if label == catalogue[3]: if label == default:
sel = i sel = i
i += 1 i += 1
self.seclabel_combo.set_active(sel) self.seclabel_combo.set_active(sel)
@ -376,6 +380,8 @@ class ChatControlBase(MessageControl, ChatCommandProcessor, CommandTools):
self._nec_ping) self._nec_ping)
app.ged.register_event_handler('ping-error', ged.GUI1, app.ged.register_event_handler('ping-error', ged.GUI1,
self._nec_ping) self._nec_ping)
app.ged.register_event_handler('sec-label-received', ged.GUI1,
self._sec_labels_received)
# This is basically a very nasty hack to surpass the inability # This is basically a very nasty hack to surpass the inability
# to properly use the super, because of the old code. # to properly use the super, because of the old code.
@ -550,6 +556,8 @@ class ChatControlBase(MessageControl, ChatCommandProcessor, CommandTools):
'chat_control_base_draw_banner', self) 'chat_control_base_draw_banner', self)
app.ged.remove_event_handler('our-show', ged.GUI1, app.ged.remove_event_handler('our-show', ged.GUI1,
self._nec_our_status) self._nec_our_status)
app.ged.remove_event_handler('sec-label-received', ged.GUI1,
self._sec_labels_received)
def on_msg_textview_populate_popup(self, textview, menu): def on_msg_textview_populate_popup(self, textview, menu):
""" """
@ -782,9 +790,11 @@ class ChatControlBase(MessageControl, ChatCommandProcessor, CommandTools):
if self.seclabel_combo is not None: if self.seclabel_combo is not None:
idx = self.seclabel_combo.get_active() idx = self.seclabel_combo.get_active()
if idx != -1: if idx != -1:
cat = app.connections[self.account].seclabel_catalogues[self.contact.jid] con = app.connections[self.account]
lname = cat[2][idx] catalog = con.get_module('SecLabels').get_catalog(self.contact.jid)
label = cat[1][lname] labels, label_list, _ = catalog
lname = label_list[idx]
label = labels[lname]
return label return label
def send_message(self, message, keyID='', type_='chat', chatstate=None, def send_message(self, message, keyID='', type_='chat', chatstate=None,

View File

@ -103,9 +103,6 @@ class CommonConnection:
self.priority = app.get_priority(name, 'offline') self.priority = app.get_priority(name, 'offline')
self.time_to_reconnect = None self.time_to_reconnect = None
self.seclabel_supported = False
self.seclabel_catalogues = {}
self.pep_supported = False self.pep_supported = False
self.pep = {} self.pep = {}
# Do we continue connection when we get roster (send presence,get vcard..) # Do we continue connection when we get roster (send presence,get vcard..)
@ -1617,7 +1614,7 @@ class Connection(CommonConnection, ConnectionHandlers):
if obj.fjid == hostname: if obj.fjid == hostname:
if nbxmpp.NS_SECLABEL in obj.features: if nbxmpp.NS_SECLABEL in obj.features:
self.seclabel_supported = True self.get_module('SecLabels').supported = True
if nbxmpp.NS_VCARD in obj.features: if nbxmpp.NS_VCARD in obj.features:
self.vcard_supported = True self.vcard_supported = True
get_action(self.name + '-profile').set_enabled(True) get_action(self.name + '-profile').set_enabled(True)
@ -1897,16 +1894,6 @@ class Connection(CommonConnection, ConnectionHandlers):
query.setTagData('prompt', prompt) query.setTagData('prompt', prompt)
self.connection.SendAndCallForResponse(iq, _on_prompt_result) self.connection.SendAndCallForResponse(iq, _on_prompt_result)
def seclabel_catalogue(self, to, callback):
if not app.account_is_connected(self.name):
return
self.seclabel_catalogue_request(to, callback)
server = app.get_jid_from_account(self.name).split("@")[1] # Really, no better way?
iq = nbxmpp.Iq(typ='get', to=server)
iq2 = iq.addChild(name='catalog', namespace=nbxmpp.NS_SECLABEL_CATALOG)
iq2.setAttr('to', to)
self.connection.send(iq)
def bookmarks_available(self): def bookmarks_available(self):
if self.private_storage_supported: if self.private_storage_supported:
return True return True

View File

@ -784,37 +784,6 @@ class ConnectionHandlers(ConnectionSocks5Bytestream, ConnectionDisco,
conn=self, stanza=obj.stanza)) conn=self, stanza=obj.stanza))
return True return True
def _SecLabelCB(self, con, iq_obj):
"""
Security Label callback, used for catalogues.
"""
log.debug('SecLabelCB')
query = iq_obj.getTag('catalog')
to = query.getAttr('to')
items = query.getTags('item')
labels = {}
ll = []
default = None
for item in items:
label = item.getAttr('selector')
labels[label] = item.getTag('securitylabel')
ll.append(label)
if item.getAttr('default') == 'true':
default = label
if to not in self.seclabel_catalogues:
self.seclabel_catalogues[to] = [[], None, None, None]
self.seclabel_catalogues[to][1] = labels
self.seclabel_catalogues[to][2] = ll
self.seclabel_catalogues[to][3] = default
for callback in self.seclabel_catalogues[to][0]:
callback()
self.seclabel_catalogues[to][0] = []
def seclabel_catalogue_request(self, to, callback):
if to not in self.seclabel_catalogues:
self.seclabel_catalogues[to] = [[], None, None, None]
self.seclabel_catalogues[to][0].append(callback)
def _rosterSetCB(self, con, iq_obj): def _rosterSetCB(self, con, iq_obj):
log.debug('rosterSetCB') log.debug('rosterSetCB')
app.nec.push_incoming_event(RosterSetReceivedEvent(None, conn=self, app.nec.push_incoming_event(RosterSetReceivedEvent(None, conn=self,
@ -1169,8 +1138,6 @@ class ConnectionHandlers(ConnectionSocks5Bytestream, ConnectionDisco,
nbxmpp.NS_DISCO_INFO) nbxmpp.NS_DISCO_INFO)
con.RegisterHandler('iq', self._DiscoverInfoErrorCB, 'error', con.RegisterHandler('iq', self._DiscoverInfoErrorCB, 'error',
nbxmpp.NS_DISCO_INFO) nbxmpp.NS_DISCO_INFO)
con.RegisterHandler('iq', self._SecLabelCB, 'result',
nbxmpp.NS_SECLABEL_CATALOG)
con.RegisterHandler('iq', self._DiscoverInfoGetCB, 'get', con.RegisterHandler('iq', self._DiscoverInfoGetCB, 'get',
nbxmpp.NS_DISCO_INFO) nbxmpp.NS_DISCO_INFO)
con.RegisterHandler('iq', self._DiscoverItemsGetCB, 'get', con.RegisterHandler('iq', self._DiscoverItemsGetCB, 'get',

View File

@ -670,11 +670,8 @@ class GcMessageReceivedEvent(nec.NetworkIncomingEvent):
form_node=self.msg_obj.form_node) form_node=self.msg_obj.form_node)
return return
self.displaymarking = None from gajim.common.modules.security_labels import parse_securitylabel
seclabel = self.stanza.getTag('securitylabel') self.displaymarking = parse_securitylabel(self.stanza)
if seclabel and seclabel.getNamespace() == nbxmpp.NS_SECLABEL:
# Ignore message from room in which we are not
self.displaymarking = seclabel.getTag('displaymarking')
self.captcha_form = None self.captcha_form = None
captcha_tag = self.stanza.getTag('captcha', namespace=nbxmpp.NS_CAPTCHA) captcha_tag = self.stanza.getTag('captcha', namespace=nbxmpp.NS_CAPTCHA)

View File

@ -22,6 +22,7 @@ import nbxmpp
from gajim.common import app from gajim.common import app
from gajim.common import helpers from gajim.common import helpers
from gajim.common.nec import NetworkIncomingEvent, NetworkEvent from gajim.common.nec import NetworkIncomingEvent, NetworkEvent
from gajim.common.modules.security_labels import parse_securitylabel
from gajim.common.modules.user_nickname import parse_nickname from gajim.common.modules.user_nickname import parse_nickname
from gajim.common.modules.chatstates import parse_chatstate from gajim.common.modules.chatstates import parse_chatstate
from gajim.common.modules.carbons import parse_carbon from gajim.common.modules.carbons import parse_carbon
@ -29,7 +30,6 @@ from gajim.common.modules.misc import parse_delay
from gajim.common.modules.misc import parse_eme from gajim.common.modules.misc import parse_eme
from gajim.common.modules.misc import parse_correction from gajim.common.modules.misc import parse_correction
from gajim.common.modules.misc import parse_attention from gajim.common.modules.misc import parse_attention
from gajim.common.modules.misc import parse_securitylabel
from gajim.common.modules.misc import parse_form from gajim.common.modules.misc import parse_form
from gajim.common.modules.misc import parse_oob from gajim.common.modules.misc import parse_oob
from gajim.common.modules.misc import parse_xhtml from gajim.common.modules.misc import parse_xhtml

View File

@ -126,15 +126,6 @@ def parse_attention(stanza):
return True return True
# XEP-0258: Security Labels in XMPP
def parse_securitylabel(stanza):
seclabel = stanza.getTag('securitylabel', namespace=nbxmpp.NS_SECLABEL)
if seclabel is None:
return None
return seclabel.getTag('displaymarking')
# XEP-0004: Data Forms # XEP-0004: Data Forms
def parse_form(stanza): def parse_form(stanza):

View File

@ -0,0 +1,88 @@
# This file is part of Gajim.
#
# Gajim is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published
# by the Free Software Foundation; version 3 only.
#
# Gajim is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Gajim. If not, see <http://www.gnu.org/licenses/>.
# XEP-0258: Security Labels in XMPP
import logging
import nbxmpp
from gajim.common import app
from gajim.common.nec import NetworkIncomingEvent
log = logging.getLogger('gajim.c.m.security_labels')
class SecLabels:
def __init__(self, con):
self._con = con
self._account = con.name
self.handlers = []
self._catalogs = {}
self.supported = False
def request_catalog(self, jid):
server = app.get_jid_from_account(self._account).split("@")[1]
iq = nbxmpp.Iq(typ='get', to=server)
iq.addChild(name='catalog',
namespace=nbxmpp.NS_SECLABEL_CATALOG,
attrs={'to': jid})
log.info('Request catalog: server: %s, to: %s', server, jid)
self._con.connection.SendAndCallForResponse(
iq, self._catalog_received)
def _catalog_received(self, stanza):
if not nbxmpp.isResultNode(stanza):
log.info('Error: %s', stanza.getError())
return
query = stanza.getTag('catalog', namespace=nbxmpp.NS_SECLABEL_CATALOG)
to = query.getAttr('to')
items = query.getTags('item')
labels = {}
label_list = []
default = None
for item in items:
label = item.getAttr('selector')
labels[label] = item.getTag('securitylabel')
label_list.append(label)
if item.getAttr('default') == 'true':
default = label
catalog = (labels, label_list, default)
self._catalogs[to] = catalog
app.nec.push_incoming_event(SecLabelCatalog(
None, account=self._account, jid=to, catalog=catalog))
def get_catalog(self, jid):
return self._catalogs.get(jid)
def parse_securitylabel(stanza):
seclabel = stanza.getTag('securitylabel', namespace=nbxmpp.NS_SECLABEL)
if seclabel is None:
return None
return seclabel.getTag('displaymarking')
class SecLabelCatalog(NetworkIncomingEvent):
name = 'sec-catalog-received'
def get_instance(*args, **kwargs):
return SecLabels(*args, **kwargs), 'SecLabels'