gajim now support when a user is logged twice with 2 differents resources
This commit is contained in:
parent
241769ca27
commit
c5570e33a0
|
@ -119,7 +119,7 @@ class GajimCore:
|
||||||
def messageCB(self, con, msg):
|
def messageCB(self, con, msg):
|
||||||
"""Called when we recieve a message"""
|
"""Called when we recieve a message"""
|
||||||
self.hub.sendPlugin('MSG', self.connexions[con], \
|
self.hub.sendPlugin('MSG', self.connexions[con], \
|
||||||
(msg.getFrom().getBasic(), msg.getBody()))
|
(msg.getFrom(), msg.getBody()))
|
||||||
# END messageCB
|
# END messageCB
|
||||||
|
|
||||||
def presenceCB(self, con, prs):
|
def presenceCB(self, con, prs):
|
||||||
|
@ -147,7 +147,8 @@ class GajimCore:
|
||||||
con.send(common.jabber.Presence(who, 'subscribed'))
|
con.send(common.jabber.Presence(who, 'subscribed'))
|
||||||
if string.find(who, "@") <= 0:
|
if string.find(who, "@") <= 0:
|
||||||
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
||||||
(who, 'offline', 'offline', prs.getFrom().getResource()))
|
(prs.getFrom().getBasic(), 'offline', 'offline', \
|
||||||
|
prs.getFrom().getResource()))
|
||||||
else:
|
else:
|
||||||
txt = prs.getStatus()
|
txt = prs.getStatus()
|
||||||
if not txt:
|
if not txt:
|
||||||
|
|
|
@ -384,7 +384,16 @@ class roster_Window:
|
||||||
"""Add a user to the roster and add groups if they aren't in roster"""
|
"""Add a user to the roster and add groups if they aren't in roster"""
|
||||||
showOffline = self.plugin.config['showoffline']
|
showOffline = self.plugin.config['showoffline']
|
||||||
if not self.contacts[account].has_key(user.jid):
|
if not self.contacts[account].has_key(user.jid):
|
||||||
self.contacts[account][user.jid] = user
|
self.contacts[account][user.jid] = [user]
|
||||||
|
else:
|
||||||
|
resources = []
|
||||||
|
for u in self.contacts[account][user.jid]:
|
||||||
|
resources.append(u.resource)
|
||||||
|
if resources == ['']:
|
||||||
|
self.contacts[account][user.jid][0].resource = user.resource
|
||||||
|
else:
|
||||||
|
if not user.resource in resources:
|
||||||
|
self.contacts[account][user.jid].append(user)
|
||||||
if user.groups == []:
|
if user.groups == []:
|
||||||
if string.find(user.jid, "@") <= 0:
|
if string.find(user.jid, "@") <= 0:
|
||||||
user.groups.append('Agents')
|
user.groups.append('Agents')
|
||||||
|
@ -465,8 +474,8 @@ class roster_Window:
|
||||||
self.tree.get_model().clear()
|
self.tree.get_model().clear()
|
||||||
for acct in self.contacts.keys():
|
for acct in self.contacts.keys():
|
||||||
self.add_account_to_roster(acct)
|
self.add_account_to_roster(acct)
|
||||||
for user in self.contacts[acct].values():
|
for luser in self.contacts[acct].values():
|
||||||
self.add_user_to_roster(user, acct)
|
self.add_user_to_roster(luser[0], acct)
|
||||||
|
|
||||||
def mklists(self, array, account):
|
def mklists(self, array, account):
|
||||||
"""fill self.contacts and self.groups"""
|
"""fill self.contacts and self.groups"""
|
||||||
|
@ -496,7 +505,9 @@ class roster_Window:
|
||||||
|
|
||||||
user1 = user(ji, name, array[jid]['groups'], show, \
|
user1 = user(ji, name, array[jid]['groups'], show, \
|
||||||
array[jid]['status'], array[jid]['sub'], resource)
|
array[jid]['status'], array[jid]['sub'], resource)
|
||||||
self.contacts[account][ji] = user1
|
#when we draw the roster, we can't have twice the same user with
|
||||||
|
# 2 resources
|
||||||
|
self.contacts[account][ji] = [user1]
|
||||||
for g in array[jid]['groups'] :
|
for g in array[jid]['groups'] :
|
||||||
if not g in self.groups[account].keys():
|
if not g in self.groups[account].keys():
|
||||||
self.groups[account][g] = {'expand':True}
|
self.groups[account][g] = {'expand':True}
|
||||||
|
@ -510,7 +521,15 @@ class roster_Window:
|
||||||
else:
|
else:
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
if (show == 'offline' or show == 'error') and not showOffline:
|
if (show == 'offline' or show == 'error') and not showOffline:
|
||||||
self.remove_user(user, account)
|
if len(self.contacts[account][user.jid]) > 1:
|
||||||
|
luser = self.contacts[account][user.jid]
|
||||||
|
user1 = None
|
||||||
|
for u in luser:
|
||||||
|
if u.resource == user.resource:
|
||||||
|
luser.remove(u)
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
self.remove_user(user, account)
|
||||||
else:
|
else:
|
||||||
for i in iters:
|
for i in iters:
|
||||||
if self.pixbufs.has_key(show):
|
if self.pixbufs.has_key(show):
|
||||||
|
@ -547,7 +566,7 @@ class roster_Window:
|
||||||
path = model.get_path(iter)
|
path = model.get_path(iter)
|
||||||
acct_iter = model.get_iter((path[0]))
|
acct_iter = model.get_iter((path[0]))
|
||||||
account = model.get_value(acct_iter, 3)
|
account = model.get_value(acct_iter, 3)
|
||||||
user = self.contacts[account][jid]
|
user = self.contacts[account][jid][0]
|
||||||
|
|
||||||
menu = gtk.Menu()
|
menu = gtk.Menu()
|
||||||
item = gtk.MenuItem(_("Start chat"))
|
item = gtk.MenuItem(_("Start chat"))
|
||||||
|
@ -610,13 +629,13 @@ class roster_Window:
|
||||||
account = model.get_value(acct_iter, 3)
|
account = model.get_value(acct_iter, 3)
|
||||||
menu = gtk.Menu()
|
menu = gtk.Menu()
|
||||||
item = gtk.MenuItem(_("Log on"))
|
item = gtk.MenuItem(_("Log on"))
|
||||||
if self.contacts[account][jid].show != 'offline':
|
if self.contacts[account][jid][0].show != 'offline':
|
||||||
item.set_sensitive(FALSE)
|
item.set_sensitive(FALSE)
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
item.connect("activate", self.on_agent_logging, jid, 'available', account)
|
item.connect("activate", self.on_agent_logging, jid, 'available', account)
|
||||||
|
|
||||||
item = gtk.MenuItem(_("Log off"))
|
item = gtk.MenuItem(_("Log off"))
|
||||||
if self.contacts[account][jid].show == 'offline':
|
if self.contacts[account][jid][0].show == 'offline':
|
||||||
item.set_sensitive(FALSE)
|
item.set_sensitive(FALSE)
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
item.connect("activate", self.on_agent_logging, jid, 'unavailable', account)
|
item.connect("activate", self.on_agent_logging, jid, 'unavailable', account)
|
||||||
|
@ -733,8 +752,9 @@ class roster_Window:
|
||||||
window = confirm_Window(_("Are you sure you want to remove %s (%s) from your roster ?") % (user.name, user.jid))
|
window = confirm_Window(_("Are you sure you want to remove %s (%s) from your roster ?") % (user.name, user.jid))
|
||||||
if window.wait() == gtk.RESPONSE_OK:
|
if window.wait() == gtk.RESPONSE_OK:
|
||||||
self.plugin.send('UNSUB', account, user.jid)
|
self.plugin.send('UNSUB', account, user.jid)
|
||||||
self.remove_user(user, account)
|
for u in self.contacts[account][user.jid]:
|
||||||
del self.contacts[account][user.jid]
|
self.remove_user(u, account)
|
||||||
|
del self.contacts[account][u.jid]
|
||||||
|
|
||||||
def change_status(self, widget, account, status):
|
def change_status(self, widget, account, status):
|
||||||
if status != 'online' and status != 'offline':
|
if status != 'online' and status != 'offline':
|
||||||
|
@ -789,8 +809,9 @@ class roster_Window:
|
||||||
if status == 'offline':
|
if status == 'offline':
|
||||||
self.plugin.sleeper = None
|
self.plugin.sleeper = None
|
||||||
for jid in self.contacts[account]:
|
for jid in self.contacts[account]:
|
||||||
user = self.contacts[account][jid]
|
luser = self.contacts[account][jid]
|
||||||
self.chg_user_status(user, 'offline', 'Disconnected', account)
|
for user in luser:
|
||||||
|
self.chg_user_status(user, 'offline', 'Disconnected', account)
|
||||||
elif self.plugin.connected[account] == 0:
|
elif self.plugin.connected[account] == 0:
|
||||||
self.plugin.sleeper = None#common.sleepy.Sleepy(\
|
self.plugin.sleeper = None#common.sleepy.Sleepy(\
|
||||||
#self.plugin.config['autoawaytime']*60, \
|
#self.plugin.config['autoawaytime']*60, \
|
||||||
|
@ -828,7 +849,8 @@ class roster_Window:
|
||||||
else:
|
else:
|
||||||
if not self.plugin.windows[account]['chats'].has_key(jid):
|
if not self.plugin.windows[account]['chats'].has_key(jid):
|
||||||
self.plugin.windows[account]['chats'][jid] = \
|
self.plugin.windows[account]['chats'][jid] = \
|
||||||
message_Window(self.contacts[account][jid], self.plugin, account)
|
message_Window(self.contacts[account][jid][0], self.plugin, \
|
||||||
|
account)
|
||||||
if path:
|
if path:
|
||||||
self.tree.expand_row(path[0:1], FALSE)
|
self.tree.expand_row(path[0:1], FALSE)
|
||||||
self.tree.expand_row(path[0:2], FALSE)
|
self.tree.expand_row(path[0:2], FALSE)
|
||||||
|
@ -885,7 +907,7 @@ class roster_Window:
|
||||||
self.plugin.windows[account]['chats'][jid].window.present()
|
self.plugin.windows[account]['chats'][jid].window.present()
|
||||||
elif self.contacts[account].has_key(jid):
|
elif self.contacts[account].has_key(jid):
|
||||||
self.plugin.windows[account]['chats'][jid] = \
|
self.plugin.windows[account]['chats'][jid] = \
|
||||||
message_Window(self.contacts[account][jid], self.plugin, account)
|
message_Window(self.contacts[account][jid][0], self.plugin, account)
|
||||||
|
|
||||||
def on_row_expanded(self, widget, iter, path):
|
def on_row_expanded(self, widget, iter, path):
|
||||||
"""When a row is expanded :
|
"""When a row is expanded :
|
||||||
|
@ -928,7 +950,7 @@ class roster_Window:
|
||||||
acct_iter = model.get_iter((path[0]))
|
acct_iter = model.get_iter((path[0]))
|
||||||
account = model.get_value(acct_iter, 3)
|
account = model.get_value(acct_iter, 3)
|
||||||
jid = model.get_value(iter, 3)
|
jid = model.get_value(iter, 3)
|
||||||
old_text = self.contacts[account][jid].name
|
old_text = self.contacts[account][jid][0].name
|
||||||
#FIXME:If it is a double click, old_text == new_text
|
#FIXME:If it is a double click, old_text == new_text
|
||||||
if old_text == new_text:
|
if old_text == new_text:
|
||||||
if self.plugin.windows[account]['chats'].has_key(jid):
|
if self.plugin.windows[account]['chats'].has_key(jid):
|
||||||
|
@ -936,12 +958,13 @@ class roster_Window:
|
||||||
chat.xml.get_widget('Chat').present()
|
chat.xml.get_widget('Chat').present()
|
||||||
elif self.contacts[account].has_key(jid):
|
elif self.contacts[account].has_key(jid):
|
||||||
self.plugin.windows[account]['chats'][jid] = \
|
self.plugin.windows[account]['chats'][jid] = \
|
||||||
message_Window(self.contacts[account][jid], self.plugin, account)
|
message_Window(self.contacts[account][jid][0], self.plugin, account)
|
||||||
else:
|
else:
|
||||||
model.set_value(iter, 1, new_text)
|
model.set_value(iter, 1, new_text)
|
||||||
self.contacts[account][jid].name = new_text
|
for u in self.contacts[account][jid]:
|
||||||
|
u.name = new_text
|
||||||
self.plugin.send('UPDUSER', account, (jid, new_text, \
|
self.plugin.send('UPDUSER', account, (jid, new_text, \
|
||||||
self.contacts[account][jid].groups))
|
self.contacts[account][jid][0].groups))
|
||||||
|
|
||||||
def on_browse(self, widget, account):
|
def on_browse(self, widget, account):
|
||||||
"""When browse agent is selected :
|
"""When browse agent is selected :
|
||||||
|
@ -1198,10 +1221,23 @@ class plugin:
|
||||||
ji = jid
|
ji = jid
|
||||||
#Update user
|
#Update user
|
||||||
if self.roster.contacts[ev[1]].has_key(ji):
|
if self.roster.contacts[ev[1]].has_key(ji):
|
||||||
user = self.roster.contacts[ev[1]][ji]
|
luser = self.roster.contacts[ev[1]][ji]
|
||||||
user.show = ev[2][1]
|
user1 = None
|
||||||
user.status = ev[2][2]
|
resources = []
|
||||||
user.resource = resource
|
for u in luser:
|
||||||
|
resources.append(u.resource)
|
||||||
|
if u.resource == resource:
|
||||||
|
user1 = u
|
||||||
|
break
|
||||||
|
if not user1:
|
||||||
|
user1 = self.roster.contacts[ev[1]][ji][0]
|
||||||
|
if resources != ['']:
|
||||||
|
user1 = user(user1.jid, user1.name, user1.groups, \
|
||||||
|
user1.show, user1.status, user1.sub, user1.resource)
|
||||||
|
luser.append(user1)
|
||||||
|
user1.resource = resource
|
||||||
|
user1.show = ev[2][1]
|
||||||
|
user1.status = ev[2][2]
|
||||||
if string.find(jid, "@") <= 0:
|
if string.find(jid, "@") <= 0:
|
||||||
#It must be an agent
|
#It must be an agent
|
||||||
if not self.roster.contacts[ev[1]].has_key(ji):
|
if not self.roster.contacts[ev[1]].has_key(ji):
|
||||||
|
@ -1215,7 +1251,7 @@ class plugin:
|
||||||
model.set_value(i, 0, self.roster.pixbufs[ev[2][1]])
|
model.set_value(i, 0, self.roster.pixbufs[ev[2][1]])
|
||||||
elif self.roster.contacts[ev[1]].has_key(ji):
|
elif self.roster.contacts[ev[1]].has_key(ji):
|
||||||
#It isn't an agent
|
#It isn't an agent
|
||||||
self.roster.chg_user_status(user, ev[2][1], ev[2][2], ev[1])
|
self.roster.chg_user_status(user1, ev[2][1], ev[2][2], ev[1])
|
||||||
#('MSG', account, (user, msg))
|
#('MSG', account, (user, msg))
|
||||||
elif ev[0] == 'MSG':
|
elif ev[0] == 'MSG':
|
||||||
if string.find(ev[2][0], "@") <= 0:
|
if string.find(ev[2][0], "@") <= 0:
|
||||||
|
@ -1229,10 +1265,10 @@ class plugin:
|
||||||
#('SUBSCRIBED', account, (jid, nom, resource))
|
#('SUBSCRIBED', account, (jid, nom, resource))
|
||||||
elif ev[0] == 'SUBSCRIBED':
|
elif ev[0] == 'SUBSCRIBED':
|
||||||
if self.roster.contacts[ev[1]].has_key(ev[2][0]):
|
if self.roster.contacts[ev[1]].has_key(ev[2][0]):
|
||||||
u = self.roster.contacts[ev[1]][ev[2][0]]['user']
|
u = self.roster.contacts[ev[1]][ev[2][0]][0]
|
||||||
u.name = ev[2][1]
|
u.name = ev[2][1]
|
||||||
u.resource = ev[2][2]
|
u.resource = ev[2][2]
|
||||||
for i in self.roster.contacts[ev[1]][u.jid]['iter']:
|
for i in self.roster.get_user_iter(u.jid, ev[1]):
|
||||||
model.set_value(i, 1, u.name)
|
model.set_value(i, 1, u.name)
|
||||||
else:
|
else:
|
||||||
user1 = user(ev[2][0], ev[2][0], ['general'], 'online', \
|
user1 = user(ev[2][0], ev[2][0], ['general'], 'online', \
|
||||||
|
|
Loading…
Reference in New Issue