diff options
author | mathieui <mathieui@mathieui.net> | 2022-04-01 20:47:06 +0200 |
---|---|---|
committer | mathieui <mathieui@mathieui.net> | 2022-04-01 20:56:02 +0200 |
commit | 914ce40fd54a0b8b38b556cda37c55cceacf0bfc (patch) | |
tree | d848e3f57c2ee08b2e5e0fa610721b102a7d29d2 | |
parent | 82ff68cfacf55aa1b79aa2f84f085ca346a75a74 (diff) | |
download | slixmpp-914ce40fd54a0b8b38b556cda37c55cceacf0bfc.tar.gz slixmpp-914ce40fd54a0b8b38b556cda37c55cceacf0bfc.tar.bz2 slixmpp-914ce40fd54a0b8b38b556cda37c55cceacf0bfc.tar.xz slixmpp-914ce40fd54a0b8b38b556cda37c55cceacf0bfc.zip |
stream features: fix old "session" establishment
As it is and old and deprecated code path, nobody noticed that it was
broken by the new filtering code.
Fix #3468
-rw-r--r-- | slixmpp/xmlstream/xmlstream.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/slixmpp/xmlstream/xmlstream.py b/slixmpp/xmlstream/xmlstream.py index 9077f23c..2e81c506 100644 --- a/slixmpp/xmlstream/xmlstream.py +++ b/slixmpp/xmlstream/xmlstream.py @@ -1318,10 +1318,16 @@ class XMLStream(asyncio.BaseProtocol): # Avoid circular imports from slixmpp.stanza.rootstanza import RootStanza from slixmpp.stanza import Iq, Handshake - passthrough = ( - (isinstance(data, Iq) and data.get_plugin('bind', check=True)) - or isinstance(data, Handshake) - ) + + passthrough = False + if isinstance(data, Iq): + if data.get_plugin('bind', check=True): + passthrough = True + elif data.get_plugin('session', check=True): + passthrough = True + elif isinstance(data, Handshake): + passthrough = True + if isinstance(data, (RootStanza, str)) and not passthrough: self.__queued_stanzas.append((data, use_filters)) log.debug('NOT SENT: %s %s', type(data), data) |