Cache xep85 support but continue to violate xep85 5.1.2 for release. See #2637.

This commit is contained in:
Jean-Marie Traissard 2006-11-26 22:00:53 +00:00
parent 10c48198fd
commit 6b0664fa83
3 changed files with 17 additions and 6 deletions

View File

@ -1133,19 +1133,28 @@ class ChatControl(ChatControlBase):
chatstates_on = gajim.config.get('outgoing_chat_state_notifications') != \ chatstates_on = gajim.config.get('outgoing_chat_state_notifications') != \
'disabled' 'disabled'
composing_jep = contact.composing_jep
chatstate_to_send = None chatstate_to_send = None
if chatstates_on and contact is not None: if chatstates_on and contact is not None:
if contact.composing_jep is None: if composing_jep is None:
# no info about peer # no info about peer
# send active to discover chat state capabilities # send active to discover chat state capabilities
# this is here (and not in send_chatstate) # this is here (and not in send_chatstate)
# because we want it sent with REAL message # because we want it sent with REAL message
# (not standlone) eg. one that has body # (not standlone) eg. one that has body
# Enable 3 next lines after 0.11 release.
# Having this disabled violate xep85 5.1.2 but then we don't break
# notifications between 0.10.1 and 0.11  See #2637
# if contact.our_chatstate:
# # We already ask for xep 85, don't ask it twice
# composing_jep = 'asked_once'
chatstate_to_send = 'active' chatstate_to_send = 'active'
contact.our_chatstate = 'ask' # pseudo state contact.our_chatstate = 'ask' # pseudo state
# if peer supports jep85 and we are not 'ask', send 'active' # if peer supports jep85 and we are not 'ask', send 'active'
# NOTE: first active and 'ask' is set in gajim.py # NOTE: first active and 'ask' is set in gajim.py
elif contact.composing_jep is not False: elif composing_jep is not False:
#send active chatstate on every message (as JEP says) #send active chatstate on every message (as JEP says)
chatstate_to_send = 'active' chatstate_to_send = 'active'
contact.our_chatstate = 'active' contact.our_chatstate = 'active'
@ -1156,7 +1165,7 @@ class ChatControl(ChatControlBase):
ChatControlBase.send_message(self, message, keyID, type = 'chat', ChatControlBase.send_message(self, message, keyID, type = 'chat',
chatstate = chatstate_to_send, chatstate = chatstate_to_send,
composing_jep = contact.composing_jep) composing_jep = composing_jep)
self.print_conversation(message, self.contact.jid, encrypted = encrypted) self.print_conversation(message, self.contact.jid, encrypted = encrypted)
def check_for_possible_paused_chatstate(self, arg): def check_for_possible_paused_chatstate(self, arg):

View File

@ -733,10 +733,11 @@ class Connection(ConnectionHandlers):
# 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
if chatstate is not None: if chatstate is not None:
if composing_jep == 'JEP-0085' or not composing_jep: if (composing_jep == 'JEP-0085' or not composing_jep) and \
composing_jep != 'asked_once':
# JEP-0085 # JEP-0085
msg_iq.setTag(chatstate, namespace = common.xmpp.NS_CHATSTATES) msg_iq.setTag(chatstate, namespace = common.xmpp.NS_CHATSTATES)
if composing_jep == 'JEP-0022' or not composing_jep: if composing_jep in ('JEP-0022', 'asked_once') or not composing_jep:
# JEP-0022 # JEP-0022
chatstate_node = msg_iq.setTag('x', chatstate_node = msg_iq.setTag('x',
namespace = common.xmpp.NS_EVENT) namespace = common.xmpp.NS_EVENT)

View File

@ -592,7 +592,8 @@ class Interface:
if contact and isinstance(contact, list): if contact and isinstance(contact, list):
contact = contact[0] contact = contact[0]
if contact: if contact:
contact.composing_jep = composing_jep if contact.composing_jep != 'JEP-0085': # We cache xep85 support
contact.composing_jep = composing_jep
if chat_control and chat_control.type_id == message_control.TYPE_CHAT: if chat_control and chat_control.type_id == message_control.TYPE_CHAT:
if chatstate is not None: if chatstate is not None:
# other peer sent us reply, so he supports jep85 or jep22 # other peer sent us reply, so he supports jep85 or jep22