diff --git a/sleekxmpp/__init__.py b/sleekxmpp/__init__.py
index 894fdc7..f05e8a5 100644
--- a/sleekxmpp/__init__.py
+++ b/sleekxmpp/__init__.py
@@ -7,6 +7,7 @@
See the file license.txt for copying permission.
"""
+from __future__ import absolute_import
from . basexmpp import basexmpp
from xml.etree import cElementTree as ET
from . xmlstream.xmlstream import XMLStream
@@ -77,6 +78,11 @@ class ClientXMPP(basexmpp, XMLStream):
self.digest_auth_started = False
XMLStream.registerHandler(self, Callback('Stream Features', MatchXPath('{http://etherx.jabber.org/streams}features'), self._handleStreamFeatures, thread=True))
XMLStream.registerHandler(self, Callback('Roster Update', MatchXPath('{%s}iq/{jabber:iq:roster}query' % self.default_ns), self._handleRoster, thread=True))
+ #SASL Auth handlers
+ basexmpp.add_handler(self, "", self.handler_sasl_digest_md5_auth, instream=True)
+ basexmpp.add_handler(self, "", self.handler_sasl_digest_md5_auth_fail, instream=True)
+ basexmpp.add_handler(self, "", self.handler_auth_success, instream=True)
+ basexmpp.add_handler(self, "", self.handler_auth_fail, instream=True)
#self.registerHandler(Callback('Roster Update', MatchXMLMask("" % self.default_ns), self._handlePresenceSubscribe, thread=True))
self.registerFeature("", self.handler_starttls, True)
self.registerFeature("", self.handler_sasl_auth, True)
@@ -211,15 +217,11 @@ class ClientXMPP(basexmpp, XMLStream):
if '{urn:ietf:params:xml:ns:xmpp-tls}starttls' in self.features:
return False
logging.debug("Starting SASL Auth")
- self.add_handler("", self.handler_auth_success, instream=True)
- self.add_handler("", self.handler_auth_fail, instream=True)
sasl_mechs = xml.findall('{urn:ietf:params:xml:ns:xmpp-sasl}mechanism')
if len(sasl_mechs):
for sasl_mech in sasl_mechs:
self.features.append("sasl:%s" % sasl_mech.text)
if 'sasl:DIGEST-MD5' in self.features:
- self.add_handler("", self.handler_sasl_digest_md5_auth, instream=True)
- self.add_handler("", self.handler_sasl_digest_md5_auth_fail, instream=True)
self.sendPriorityRaw("""""")
elif 'sasl:PLAIN' in self.features:
if sys.version_info < (3,0):