some message handling fixes. see #5982. There are still problems with encrypted messages.
This commit is contained in:
parent
e4ff7c6ced
commit
03e90746b9
|
@ -1426,7 +1426,7 @@ ConnectionJingle, ConnectionIBBytestream):
|
||||||
if obj.receipt_request_tag and gajim.config.get_per('accounts',
|
if obj.receipt_request_tag and gajim.config.get_per('accounts',
|
||||||
self.name, 'answer_receipts') and ((contact and contact.sub \
|
self.name, 'answer_receipts') and ((contact and contact.sub \
|
||||||
not in (u'to', u'none')) or gc_contact) and obj.mtype != 'error':
|
not in (u'to', u'none')) or gc_contact) and obj.mtype != 'error':
|
||||||
receipt = common.xmpp.Message(to=obj.jfid, typ='chat')
|
receipt = common.xmpp.Message(to=obj.fjid, typ='chat')
|
||||||
receipt.setID(obj.id_)
|
receipt.setID(obj.id_)
|
||||||
receipt.setTag('received', namespace='urn:xmpp:receipts',
|
receipt.setTag('received', namespace='urn:xmpp:receipts',
|
||||||
attrs={'id': obj.id_})
|
attrs={'id': obj.id_})
|
||||||
|
@ -1436,9 +1436,9 @@ ConnectionJingle, ConnectionIBBytestream):
|
||||||
self.connection.send(receipt)
|
self.connection.send(receipt)
|
||||||
|
|
||||||
# We got our message's receipt
|
# We got our message's receipt
|
||||||
if obj.receipt_received_tag and self.session.control and \
|
if obj.receipt_received_tag and obj.session.control and \
|
||||||
gajim.config.get_per('accounts', self.name, 'request_receipt'):
|
gajim.config.get_per('accounts', self.name, 'request_receipt'):
|
||||||
self.session.control.conv_textview.hide_xep0184_warning(obj.id_)
|
obj.session.control.conv_textview.hide_xep0184_warning(obj.id_)
|
||||||
|
|
||||||
if obj.enc_tag and self.USE_GPG:
|
if obj.enc_tag and self.USE_GPG:
|
||||||
encmsg = obj.enc_tag.getData()
|
encmsg = obj.enc_tag.getData()
|
||||||
|
@ -1472,10 +1472,11 @@ ConnectionJingle, ConnectionIBBytestream):
|
||||||
gajim.nec.push_incoming_event(GcInvitationReceivedEvent(None,
|
gajim.nec.push_incoming_event(GcInvitationReceivedEvent(None,
|
||||||
conn=self, msg_obj=obj))
|
conn=self, msg_obj=obj))
|
||||||
else:
|
else:
|
||||||
if isinstance(session, gajim.default_session_type):
|
if isinstance(obj.session, gajim.default_session_type):
|
||||||
session.received(frm, msgtxt, tim, encrypted, msg)
|
obj.session.received(obj.fjid, obj.msgtxt, obj.timestamp,
|
||||||
|
obj.encrypted, obj.stanza)
|
||||||
else:
|
else:
|
||||||
session.received(msg)
|
obj.session.received(obj.stanza)
|
||||||
|
|
||||||
# process and dispatch an error message
|
# process and dispatch an error message
|
||||||
def dispatch_error_message(self, msg, msgtxt, session, frm, tim):
|
def dispatch_error_message(self, msg, msgtxt, session, frm, tim):
|
||||||
|
|
|
@ -1016,6 +1016,7 @@ class DecryptedMessageReceivedEvent(nec.NetworkIncomingEvent):
|
||||||
self.gc_control = self.msg_obj.gc_control
|
self.gc_control = self.msg_obj.gc_control
|
||||||
self.session = self.msg_obj.session
|
self.session = self.msg_obj.session
|
||||||
self.timestamp = self.msg_obj.timestamp
|
self.timestamp = self.msg_obj.timestamp
|
||||||
|
self.encrypted = self.msg_obj.encrypted
|
||||||
return True
|
return True
|
||||||
|
|
||||||
class GcMessageReceivedEvent(nec.NetworkIncomingEvent):
|
class GcMessageReceivedEvent(nec.NetworkIncomingEvent):
|
||||||
|
|
Loading…
Reference in New Issue