X-Git-Url: http://git.maemo.org/git/?p=theonering;a=blobdiff_plain;f=src%2Fconnection.py;h=96808cb9b794096dc953dac0e8f735ed65feaea1;hp=31ecd531429e7f5834b11fbf17a3c19fcd6b908b;hb=007e2c7b70cf9310e9e6056e24ad8f6123958a61;hpb=3b43bd098274b1944cf6dc252ec1d53b0a0ba4cb diff --git a/src/connection.py b/src/connection.py index 31ecd53..96808cb 100644 --- a/src/connection.py +++ b/src/connection.py @@ -6,7 +6,6 @@ import telepathy import constants import tp -import util.go_utils as gobject_utils import util.misc as misc_utils import gvoice @@ -140,7 +139,6 @@ class TheOneRingConnection( autogv.AutoDisconnect(weakref.ref(self)), autogv.DelayEnableContactIntegration(constants._telepathy_implementation_name_), ] - self._delayedConnect = gobject_utils.Async(self._delayed_connect) _moduleLogger.info("Connection to the account %s created" % account) self._timedDisconnect = autogv.TimedDisconnect(weakref.ref(self)) @@ -189,23 +187,27 @@ class TheOneRingConnection( if self._status != telepathy.CONNECTION_STATUS_DISCONNECTED: _moduleLogger.info("Attempting connect when not disconnected") return - _moduleLogger.info("Kicking off connect") - self._delayedConnect.start() - self._timedDisconnect.stop() - - @misc_utils.log_exception(_moduleLogger) - def _delayed_connect(self): _moduleLogger.info("Connecting...") self.StatusChanged( telepathy.CONNECTION_STATUS_CONNECTING, telepathy.CONNECTION_STATUS_REASON_REQUESTED ) + self._timedDisconnect.stop() + self.session.login( + self.__credentials[0], + self.__credentials[1], + self._on_login, + self._on_login_error, + ) + + @misc_utils.log_exception(_moduleLogger) + def _on_login(self, *args): + _moduleLogger.info("Connected, setting up...") try: self.__session.load(self.__cachePath) for plumber in self._plumbing: plumber.start() - self.session.login(*self.__credentials) if not self.__callbackNumberParameter: callback = gvoice.backend.get_sane_callback( self.session.backend @@ -219,22 +221,26 @@ class TheOneRingConnection( publishHandle = self.get_handle_by_name(telepathy.HANDLE_TYPE_LIST, "publish") publishProps = self.generate_props(telepathy.CHANNEL_TYPE_CONTACT_LIST, publishHandle, False) self.__channelManager.channel_for_props(publishProps, signal=True) - except gvoice.backend.NetworkError: - _moduleLogger.exception("Connection Failed") - self.disconnect(telepathy.CONNECTION_STATUS_REASON_NETWORK_ERROR) - return except Exception: - _moduleLogger.exception("Connection Failed") + _moduleLogger.exception("Setup failed") self.disconnect(telepathy.CONNECTION_STATUS_REASON_AUTHENTICATION_FAILED) return - _moduleLogger.info("Connected") + _moduleLogger.info("Connected and set up") self.StatusChanged( telepathy.CONNECTION_STATUS_CONNECTED, telepathy.CONNECTION_STATUS_REASON_REQUESTED ) @misc_utils.log_exception(_moduleLogger) + def _on_login_error(self, error): + _moduleLogger.error(error) + if isinstance(error, gvoice.backend.NetworkError): + self.disconnect(telepathy.CONNECTION_STATUS_REASON_NETWORK_ERROR) + else: + self.disconnect(telepathy.CONNECTION_STATUS_REASON_AUTHENTICATION_FAILED) + + @misc_utils.log_exception(_moduleLogger) def Disconnect(self): """ For org.freedesktop.telepathy.Connection @@ -282,7 +288,6 @@ class TheOneRingConnection( def disconnect(self, reason): _moduleLogger.info("Disconnecting") - self._delayedConnect.cancel() self._timedDisconnect.stop() # Not having the disconnect first can cause weird behavior with clients @@ -305,6 +310,6 @@ class TheOneRingConnection( # In case one of the above items takes too long (which it should never # do), we leave the starting of the shutdown-on-idle counter to the # very end - self.manager.disconnect_completed(self) + self.manager.disconnect_completed() _moduleLogger.info("Disconnected")