Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/services/presence2
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2007-02-26 20:38:50 (GMT)
committer Dan Williams <dcbw@redhat.com>2007-02-26 20:38:50 (GMT)
commitabf84970b513a5e00eb6524244e19e398414f372 (patch)
tree79cd61858c4dd9303a99175ad2d1723997ea2bb6 /services/presence2
parentca8f3a04847754b2a2df0220f2590f166b1c1b06 (diff)
always register the jid when connecting
Diffstat (limited to 'services/presence2')
-rw-r--r--services/presence2/server_plugin.py18
1 files changed, 5 insertions, 13 deletions
diff --git a/services/presence2/server_plugin.py b/services/presence2/server_plugin.py
index f80034c..613511c 100644
--- a/services/presence2/server_plugin.py
+++ b/services/presence2/server_plugin.py
@@ -54,7 +54,6 @@ class ServerPlugin(gobject.GObject):
self._online_contacts = set() # handles of online contacts
self._account = self._get_account_info()
- self._ever_connected = False
self._conn = self._init_connection()
def _get_account_info(self):
@@ -85,12 +84,11 @@ class ServerPlugin(gobject.GObject):
return item
return None
- def _init_connection(self, register=False):
+ def _init_connection(self):
conn = self._find_existing_connection()
if not conn:
acct = self._account.copy()
- if register:
- acct['register'] = True
+ acct['register'] = True
# Create a new connection
print acct
@@ -119,8 +117,6 @@ class ServerPlugin(gobject.GObject):
return channel
def _connected_cb(self):
- self._ever_connected = True
-
# the group of contacts who may receive your presence
publish = self._request_list_channel('publish')
publish_handles, local_pending, remote_pending = publish[CHANNEL_INTERFACE_GROUP].GetAllMembers()
@@ -190,13 +186,9 @@ class ServerPlugin(gobject.GObject):
elif state == CONNECTION_STATUS_DISCONNECTED:
print 'disconnected: %r' % reason
self.emit('status', state, int(reason))
- if reason == CONNECTION_STATUS_REASON_AUTHENTICATION_FAILED and \
- not self._ever_connected:
- # Hmm; probably aren't registered on the server, try reconnecting
- # and registering
- del self._conn
- self._conn = self._init_connection(register=True)
- self.start()
+ if reason == CONNECTION_STATUS_REASON_AUTHENTICATION_FAILED:
+ # FIXME: handle connection failure; retry later?
+ pass
return False
def start(self):