[danguy] correctly encrypt message in zeroconf network. fixes #3113
This commit is contained in:
parent
2ef20efac5
commit
b15b53b5e2
|
@ -333,12 +333,12 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
chatstate = None, msg_id = None, composing_jep = None, resource = None,
|
chatstate = None, msg_id = None, composing_jep = None, resource = None,
|
||||||
user_nick = None):
|
user_nick = None):
|
||||||
fjid = jid
|
fjid = jid
|
||||||
|
|
||||||
if not self.connection:
|
if not self.connection:
|
||||||
return
|
return
|
||||||
if not msg and chatstate is None:
|
if not msg and chatstate is None:
|
||||||
return
|
return
|
||||||
|
|
||||||
if self.status in ('invisible', 'offline'):
|
if self.status in ('invisible', 'offline'):
|
||||||
self.dispatch('MSGERROR', [unicode(jid), '-1', _('You are not connected or not visible to others. Your message could not be sent.'), None, None])
|
self.dispatch('MSGERROR', [unicode(jid), '-1', _('You are not connected or not visible to others. Your message could not be sent.'), None, None])
|
||||||
return
|
return
|
||||||
|
@ -346,19 +346,23 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
msgtxt = msg
|
msgtxt = msg
|
||||||
msgenc = ''
|
msgenc = ''
|
||||||
if keyID and USE_GPG:
|
if keyID and USE_GPG:
|
||||||
#encrypt
|
# encrypt
|
||||||
msgenc = self.gpg.encrypt(msg, [keyID])
|
msgenc, error = self.gpg.encrypt(msg, [keyID])
|
||||||
if msgenc:
|
if msgenc and not error:
|
||||||
msgtxt = '[This message is encrypted]'
|
msgtxt = '[This message is encrypted]'
|
||||||
lang = os.getenv('LANG')
|
lang = os.getenv('LANG')
|
||||||
if lang is not None or lang != 'en': # we're not english
|
if lang is not None or lang != 'en': # we're not english
|
||||||
msgtxt = _('[This message is encrypted]') +\
|
msgtxt = _('[This message is encrypted]') +\
|
||||||
' ([This message is encrypted])' # one in locale and one en
|
' ([This message is encrypted])' # one in locale and one en
|
||||||
|
else:
|
||||||
|
# Encryption failed, do not send message
|
||||||
|
tim = time.localtime()
|
||||||
|
self.dispatch('MSGNOTSENT', (jid, error, msgtxt, tim))
|
||||||
|
return 3
|
||||||
|
|
||||||
|
|
||||||
if type == 'chat':
|
if type == 'chat':
|
||||||
msg_iq = common.xmpp.Message(to = fjid, body = msgtxt, typ = type)
|
msg_iq = common.xmpp.Message(to = fjid, body = msgtxt, typ = type)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
if subject:
|
if subject:
|
||||||
msg_iq = common.xmpp.Message(to = fjid, body = msgtxt,
|
msg_iq = common.xmpp.Message(to = fjid, body = msgtxt,
|
||||||
|
@ -369,7 +373,7 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
|
|
||||||
if msgenc:
|
if msgenc:
|
||||||
msg_iq.setTag(common.xmpp.NS_ENCRYPTED + ' x').setData(msgenc)
|
msg_iq.setTag(common.xmpp.NS_ENCRYPTED + ' x').setData(msgenc)
|
||||||
|
|
||||||
# chatstates - if peer supports jep85 or jep22, send chatstates
|
# chatstates - if peer supports jep85 or jep22, send chatstates
|
||||||
# please note that the only valid tag inside a message containing a <body>
|
# please note that the only valid tag inside a message containing a <body>
|
||||||
# tag is the active event
|
# tag is the active event
|
||||||
|
@ -387,7 +391,7 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
# when msgtxt, requests JEP-0022 composing notification
|
# when msgtxt, requests JEP-0022 composing notification
|
||||||
if chatstate is 'composing' or msgtxt:
|
if chatstate is 'composing' or msgtxt:
|
||||||
chatstate_node.addChild(name = 'composing')
|
chatstate_node.addChild(name = 'composing')
|
||||||
|
|
||||||
if not self.connection.send(msg_iq, msg != None):
|
if not self.connection.send(msg_iq, msg != None):
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue