many changes :
- user class now has priority attribut - remove can only be done by the popup menu (BUG : when editing is canceled, iter stays editable. need gtk2.4 to coreect that) - cleaner code
This commit is contained in:
parent
94bab4e9ef
commit
f518f2c6e2
47
core/core.py
47
core/core.py
|
@ -125,21 +125,23 @@ class GajimCore:
|
||||||
def presenceCB(self, con, prs):
|
def presenceCB(self, con, prs):
|
||||||
"""Called when we recieve a presence"""
|
"""Called when we recieve a presence"""
|
||||||
who = str(prs.getFrom())
|
who = str(prs.getFrom())
|
||||||
|
prio = prs.getPriority()
|
||||||
|
if not prio:
|
||||||
|
prio = 0
|
||||||
type = prs.getType()
|
type = prs.getType()
|
||||||
if type == None: type = 'available'
|
if type == None: type = 'available'
|
||||||
log.debug("PresenceCB : %s" % type)
|
log.debug("PresenceCB : %s" % type)
|
||||||
if type == 'available':
|
if type == 'available':
|
||||||
if prs.getShow():
|
show = prs.getShow()
|
||||||
show = prs.getShow()
|
if not show:
|
||||||
else:
|
|
||||||
show = 'online'
|
show = 'online'
|
||||||
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
||||||
(prs.getFrom().getBasic(), show, prs.getStatus(), \
|
(prs.getFrom().getBasic(), show, prs.getStatus(), \
|
||||||
prs.getFrom().getResource()))
|
prs.getFrom().getResource(), prio))
|
||||||
elif type == 'unavailable':
|
elif type == 'unavailable':
|
||||||
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
||||||
(prs.getFrom().getBasic(), 'offline', prs.getStatus(), \
|
(prs.getFrom().getBasic(), 'offline', prs.getStatus(), \
|
||||||
prs.getFrom().getResource()))
|
prs.getFrom().getResource(), prio))
|
||||||
elif type == 'subscribe':
|
elif type == 'subscribe':
|
||||||
log.debug("subscribe request from %s" % who)
|
log.debug("subscribe request from %s" % who)
|
||||||
if self.cfgParser.Core['alwaysauth'] == 1 or \
|
if self.cfgParser.Core['alwaysauth'] == 1 or \
|
||||||
|
@ -148,7 +150,7 @@ class GajimCore:
|
||||||
if string.find(who, "@") <= 0:
|
if string.find(who, "@") <= 0:
|
||||||
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
||||||
(prs.getFrom().getBasic(), 'offline', 'offline', \
|
(prs.getFrom().getBasic(), 'offline', 'offline', \
|
||||||
prs.getFrom().getResource()))
|
prs.getFrom().getResource(), prio))
|
||||||
else:
|
else:
|
||||||
txt = prs.getStatus()
|
txt = prs.getStatus()
|
||||||
if not txt:
|
if not txt:
|
||||||
|
@ -172,7 +174,7 @@ class GajimCore:
|
||||||
errmsg = prs._node.kids[0].getData()
|
errmsg = prs._node.kids[0].getData()
|
||||||
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
self.hub.sendPlugin('NOTIFY', self.connexions[con], \
|
||||||
(prs.getFrom().getBasic(), 'error', errmsg, \
|
(prs.getFrom().getBasic(), 'error', errmsg, \
|
||||||
prs.getFrom().getResource()))
|
prs.getFrom().getResource(), prio))
|
||||||
# END presenceCB
|
# END presenceCB
|
||||||
|
|
||||||
def disconnectedCB(self, con):
|
def disconnectedCB(self, con):
|
||||||
|
@ -301,21 +303,22 @@ class GajimCore:
|
||||||
elif ev[0] == 'STATUS':
|
elif ev[0] == 'STATUS':
|
||||||
if (ev[2][0] != 'offline') and (self.connected[ev[1]] == 0):
|
if (ev[2][0] != 'offline') and (self.connected[ev[1]] == 0):
|
||||||
con = self.connect(ev[1])
|
con = self.connect(ev[1])
|
||||||
#send our presence
|
if self.connected[ev[1]]:
|
||||||
p = common.jabber.Presence()
|
#send our presence
|
||||||
p.setShow(ev[2][0])
|
p = common.jabber.Presence()
|
||||||
p.setStatus(ev[2][1])
|
p.setShow(ev[2][0])
|
||||||
if ev[2][0] == 'invisible':
|
p.setStatus(ev[2][1])
|
||||||
p.setType('invisible')
|
if ev[2][0] == 'invisible':
|
||||||
con.send(p)
|
p.setType('invisible')
|
||||||
self.hub.sendPlugin('STATUS', ev[1], ev[2][0])
|
con.send(p)
|
||||||
#ask our VCard
|
self.hub.sendPlugin('STATUS', ev[1], ev[2][0])
|
||||||
iq = common.jabber.Iq(type="get")
|
#ask our VCard
|
||||||
iq._setTag('vCard', common.jabber.NS_VCARD)
|
iq = common.jabber.Iq(type="get")
|
||||||
id = con.getAnID()
|
iq._setTag('vCard', common.jabber.NS_VCARD)
|
||||||
iq.setID(id)
|
id = con.getAnID()
|
||||||
con.send(iq)
|
iq.setID(id)
|
||||||
self.myVCardID.append(id)
|
con.send(iq)
|
||||||
|
self.myVCardID.append(id)
|
||||||
elif (ev[2][0] == 'offline') and (self.connected[ev[1]] == 1):
|
elif (ev[2][0] == 'offline') and (self.connected[ev[1]] == 1):
|
||||||
self.connected[ev[1]] = 0
|
self.connected[ev[1]] = 0
|
||||||
con.disconnect()
|
con.disconnect()
|
||||||
|
|
|
@ -44,9 +44,10 @@ class user:
|
||||||
self.groups = []
|
self.groups = []
|
||||||
self.show = ''
|
self.show = ''
|
||||||
self.status = ''
|
self.status = ''
|
||||||
self.sub == ''
|
self.sub = ''
|
||||||
self.resource == ''
|
self.resource = ''
|
||||||
elif len(args) == 7:
|
self.priority = 0
|
||||||
|
elif len(args) == 8:
|
||||||
self.jid = args[0]
|
self.jid = args[0]
|
||||||
self.name = args[1]
|
self.name = args[1]
|
||||||
self.groups = args[2]
|
self.groups = args[2]
|
||||||
|
@ -54,6 +55,7 @@ class user:
|
||||||
self.status = args[4]
|
self.status = args[4]
|
||||||
self.sub = args[5]
|
self.sub = args[5]
|
||||||
self.resource = args[6]
|
self.resource = args[6]
|
||||||
|
self.priority = args[7]
|
||||||
else: raise TypeError, _('bad arguments')
|
else: raise TypeError, _('bad arguments')
|
||||||
|
|
||||||
|
|
||||||
|
@ -380,20 +382,22 @@ class roster_Window:
|
||||||
model.append(None, (self.pixbufs[status], account, 'account', account,\
|
model.append(None, (self.pixbufs[status], account, 'account', account,\
|
||||||
FALSE))
|
FALSE))
|
||||||
|
|
||||||
def add_user_to_roster(self, user, account):
|
def add_user_to_roster(self, jid, account):
|
||||||
"""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(jid):
|
||||||
self.contacts[account][user.jid] = [user]
|
return
|
||||||
else:
|
users = self.contacts[account][jid]
|
||||||
resources = []
|
user = users[0]
|
||||||
for u in self.contacts[account][user.jid]:
|
# else:
|
||||||
resources.append(u.resource)
|
# resources = []
|
||||||
if resources == ['']:
|
# for u in self.contacts[account][user.jid]:
|
||||||
self.contacts[account][user.jid][0].resource = user.resource
|
# resources.append(u.resource)
|
||||||
else:
|
# if resources == ['']:
|
||||||
if not user.resource in resources:
|
# self.contacts[account][user.jid][0].resource = user.resource
|
||||||
self.contacts[account][user.jid].append(user)
|
# 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')
|
||||||
|
@ -408,8 +412,8 @@ class roster_Window:
|
||||||
for g in user.groups:
|
for g in user.groups:
|
||||||
iterG = self.get_group_iter(g, account)
|
iterG = self.get_group_iter(g, account)
|
||||||
if not iterG:
|
if not iterG:
|
||||||
acct = self.get_account_iter(account)
|
IterAcct = self.get_account_iter(account)
|
||||||
iterG = model.append(acct, \
|
iterG = model.append(IterAcct, \
|
||||||
(self.pixbufs['closed'], g, 'group', \
|
(self.pixbufs['closed'], g, 'group', \
|
||||||
g, FALSE))
|
g, FALSE))
|
||||||
if not self.groups[account].has_key(g):
|
if not self.groups[account].has_key(g):
|
||||||
|
@ -421,10 +425,11 @@ class roster_Window:
|
||||||
typestr = 'agent'
|
typestr = 'agent'
|
||||||
|
|
||||||
model.append(iterG, (self.pixbufs[user.show], \
|
model.append(iterG, (self.pixbufs[user.show], \
|
||||||
user.name, typestr, user.jid, TRUE))
|
user.name, typestr, user.jid, False))
|
||||||
|
|
||||||
if self.groups[account][g]['expand']:
|
if self.groups[account][g]['expand']:
|
||||||
self.tree.expand_row(model.get_path(iterG), FALSE)
|
self.tree.expand_row(model.get_path(iterG), False)
|
||||||
|
self.redraw_jid(jid, account)
|
||||||
|
|
||||||
def remove_user(self, user, account):
|
def remove_user(self, user, account):
|
||||||
"""Remove a user from the roster"""
|
"""Remove a user from the roster"""
|
||||||
|
@ -435,6 +440,26 @@ class roster_Window:
|
||||||
if model.iter_n_children(parent_i) == 0:
|
if model.iter_n_children(parent_i) == 0:
|
||||||
model.remove(parent_i)
|
model.remove(parent_i)
|
||||||
|
|
||||||
|
def redraw_jid(self, jid, account):
|
||||||
|
"""draw the correct pixbuf and name"""
|
||||||
|
model = self.tree.get_model()
|
||||||
|
iters = self.get_user_iter(jid, account)
|
||||||
|
if len(iters) == 0:
|
||||||
|
return
|
||||||
|
users = self.contacts[account][jid]
|
||||||
|
name = users[0].name
|
||||||
|
if len(users) > 1:
|
||||||
|
name += " (" + str(len(users)) + ")"
|
||||||
|
prio = 0
|
||||||
|
show = users[0].show
|
||||||
|
for u in users:
|
||||||
|
if u.priority > prio:
|
||||||
|
prio = u.priority
|
||||||
|
show = u.show
|
||||||
|
for iter in iters:
|
||||||
|
model.set_value(iter, 0, self.pixbufs[show])
|
||||||
|
model.set_value(iter, 1, name)
|
||||||
|
|
||||||
def mkmenu(self):
|
def mkmenu(self):
|
||||||
"""create the browse agents and add sub menus"""
|
"""create the browse agents and add sub menus"""
|
||||||
if len(self.plugin.accounts.keys()) > 0:
|
if len(self.plugin.accounts.keys()) > 0:
|
||||||
|
@ -474,8 +499,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 luser in self.contacts[acct].values():
|
for jid in self.contacts[acct].keys():
|
||||||
self.add_user_to_roster(luser[0], acct)
|
self.add_user_to_roster(jid, acct)
|
||||||
|
|
||||||
def mklists(self, array, account):
|
def mklists(self, array, account):
|
||||||
"""fill self.contacts and self.groups"""
|
"""fill self.contacts and self.groups"""
|
||||||
|
@ -504,7 +529,7 @@ class roster_Window:
|
||||||
show = 'offline'
|
show = 'offline'
|
||||||
|
|
||||||
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, 0)
|
||||||
#when we draw the roster, we can't have twice the same user with
|
#when we draw the roster, we can't have twice the same user with
|
||||||
# 2 resources
|
# 2 resources
|
||||||
self.contacts[account][ji] = [user1]
|
self.contacts[account][ji] = [user1]
|
||||||
|
@ -515,33 +540,22 @@ class roster_Window:
|
||||||
def chg_user_status(self, user, show, status, account):
|
def chg_user_status(self, user, show, status, account):
|
||||||
"""When a user change his status"""
|
"""When a user change his status"""
|
||||||
showOffline = self.plugin.config['showoffline']
|
showOffline = self.plugin.config['showoffline']
|
||||||
iters = self.get_user_iter(user.jid, account)
|
model = self.tree.get_model()
|
||||||
if not iters:
|
if (show == 'offline' or show == 'error') and not showOffline:
|
||||||
self.add_user_to_roster(user, account)
|
if len(self.contacts[account][user.jid]) > 1:
|
||||||
else:
|
luser = self.contacts[account][user.jid]
|
||||||
model = self.tree.get_model()
|
for u in luser:
|
||||||
if (show == 'offline' or show == 'error') and not showOffline:
|
if u.resource == user.resource:
|
||||||
if len(self.contacts[account][user.jid]) > 1:
|
luser.remove(u)
|
||||||
luser = self.contacts[account][user.jid]
|
self.redraw_jid(user.jid, account)
|
||||||
for u in luser:
|
break
|
||||||
if u.resource == user.resource:
|
|
||||||
luser.remove(u)
|
|
||||||
break
|
|
||||||
else:
|
|
||||||
self.remove_user(user, account)
|
|
||||||
iters = []
|
|
||||||
else:
|
else:
|
||||||
#TODO: should show pibuf of the prioritest resource
|
self.remove_user(user, account)
|
||||||
for i in iters:
|
iters = []
|
||||||
if self.pixbufs.has_key(show):
|
else:
|
||||||
model.set_value(i, 0, self.pixbufs[show])
|
if not self.get_user_iter(user.jid, account):
|
||||||
l = len(self.contacts[account][user.jid])
|
self.add_user_to_roster(user.jid, account)
|
||||||
if l > 1:
|
self.redraw_jid(user.jid, account)
|
||||||
for iter in iters:
|
|
||||||
model.set_value(iter, 1, user.name + " (" + str(l) + ")")
|
|
||||||
elif l == 1:
|
|
||||||
for iter in iters:
|
|
||||||
model.set_value(iter, 1, user.name)
|
|
||||||
for u in self.contacts[account][user.jid]:
|
for u in self.contacts[account][user.jid]:
|
||||||
if u.resource == user.resource:
|
if u.resource == user.resource:
|
||||||
u.show = show
|
u.show = show
|
||||||
|
@ -569,7 +583,10 @@ class roster_Window:
|
||||||
"""When an agent is requested to log in or off"""
|
"""When an agent is requested to log in or off"""
|
||||||
self.plugin.send('AGENT_LOGGING', account, (jid, state))
|
self.plugin.send('AGENT_LOGGING', account, (jid, state))
|
||||||
|
|
||||||
def on_rename(self, widget, path):
|
def on_rename(self, widget, iter, path, user):
|
||||||
|
model = self.tree.get_model()
|
||||||
|
model.set_value(iter, 1, user.name)
|
||||||
|
model.set_value(iter, 4, True)
|
||||||
self.tree.set_cursor(path, self.tree.get_column(0), True)
|
self.tree.set_cursor(path, self.tree.get_column(0), True)
|
||||||
|
|
||||||
def on_history(self, widget, user):
|
def on_history(self, widget, user):
|
||||||
|
@ -593,7 +610,7 @@ class roster_Window:
|
||||||
item.connect("activate", self.on_row_activated, path)
|
item.connect("activate", self.on_row_activated, path)
|
||||||
item = gtk.MenuItem(_("Rename"))
|
item = gtk.MenuItem(_("Rename"))
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
item.connect("activate", self.on_rename, path)
|
item.connect("activate", self.on_rename, iter, path, user)
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
item = gtk.MenuItem(_("Subscription"))
|
item = gtk.MenuItem(_("Subscription"))
|
||||||
|
@ -733,8 +750,9 @@ class roster_Window:
|
||||||
self.plugin.send('SUB', account, (jid, txt))
|
self.plugin.send('SUB', account, (jid, txt))
|
||||||
if not self.contacts[account].has_key(jid):
|
if not self.contacts[account].has_key(jid):
|
||||||
user1 = user(jid, jid, ['general'], 'requested', \
|
user1 = user(jid, jid, ['general'], 'requested', \
|
||||||
'requested', 'sub', '')
|
'requested', 'sub', '', 0)
|
||||||
self.add_user_to_roster(user1, account)
|
self.contacts[account][jid] = [user1]
|
||||||
|
self.add_user_to_roster(jid, account)
|
||||||
|
|
||||||
def on_treeview_event(self, widget, event):
|
def on_treeview_event(self, widget, event):
|
||||||
"""popup user's group's or agent menu"""
|
"""popup user's group's or agent menu"""
|
||||||
|
@ -854,8 +872,9 @@ class roster_Window:
|
||||||
"""when we receive a message"""
|
"""when we receive a message"""
|
||||||
if not self.contacts[account].has_key(jid):
|
if not self.contacts[account].has_key(jid):
|
||||||
user1 = user(jid, jid, ['not in list'], \
|
user1 = user(jid, jid, ['not in list'], \
|
||||||
'not in list', 'not in list', 'none', '')
|
'not in list', 'not in list', 'none', '', 0)
|
||||||
self.add_user_to_roster(user1, account)
|
self.contacts[account][jid] = [user1]
|
||||||
|
self.add_user_to_roster(jid, account)
|
||||||
iter = self.get_user_iter(jid, account)
|
iter = self.get_user_iter(jid, account)
|
||||||
if iter:
|
if iter:
|
||||||
path = self.tree.get_model().get_path(iter[0])
|
path = self.tree.get_model().get_path(iter[0])
|
||||||
|
@ -971,10 +990,15 @@ class roster_Window:
|
||||||
jid = model.get_value(iter, 3)
|
jid = model.get_value(iter, 3)
|
||||||
self.groups[account][jid]['expand'] = False
|
self.groups[account][jid]['expand'] = False
|
||||||
|
|
||||||
|
def on_editing_canceled (self, cell):
|
||||||
|
"""editing have been canceled"""
|
||||||
|
#TODO: get iter
|
||||||
|
#model.set_value(iter, 4, False)
|
||||||
|
pass
|
||||||
|
|
||||||
def on_cell_edited (self, cell, row, new_text):
|
def on_cell_edited (self, cell, row, new_text):
|
||||||
"""When an iter is editer :
|
"""When an iter is editer :
|
||||||
if text has changed, rename the user
|
if text has changed, rename the user"""
|
||||||
else open chat window"""
|
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
iter = model.get_iter_from_string(row)
|
iter = model.get_iter_from_string(row)
|
||||||
path = model.get_path(iter)
|
path = model.get_path(iter)
|
||||||
|
@ -982,20 +1006,13 @@ class roster_Window:
|
||||||
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][0].name
|
old_text = self.contacts[account][jid][0].name
|
||||||
#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):
|
|
||||||
chat = self.plugin.windows[account]['chats'][jid]
|
|
||||||
chat.xml.get_widget('Chat').present()
|
|
||||||
elif self.contacts[account].has_key(jid):
|
|
||||||
self.plugin.windows[account]['chats'][jid] = \
|
|
||||||
message_Window(self.contacts[account][jid][0], self.plugin, account)
|
|
||||||
else:
|
|
||||||
model.set_value(iter, 1, new_text)
|
|
||||||
for u in self.contacts[account][jid]:
|
for u in self.contacts[account][jid]:
|
||||||
u.name = new_text
|
u.name = new_text
|
||||||
self.plugin.send('UPDUSER', account, (jid, new_text, \
|
self.plugin.send('UPDUSER', account, (jid, new_text, \
|
||||||
self.contacts[account][jid][0].groups))
|
self.contacts[account][jid][0].groups))
|
||||||
|
model.set_value(iter, 4, False)
|
||||||
|
self.redraw_jid(jid, account)
|
||||||
|
|
||||||
def on_browse(self, widget, account):
|
def on_browse(self, widget, account):
|
||||||
"""When browse agent is selected :
|
"""When browse agent is selected :
|
||||||
|
@ -1111,23 +1128,6 @@ class roster_Window:
|
||||||
model.set_sort_column_id(1, gtk.SORT_ASCENDING)
|
model.set_sort_column_id(1, gtk.SORT_ASCENDING)
|
||||||
self.tree.set_model(model)
|
self.tree.set_model(model)
|
||||||
self.mkpixbufs()
|
self.mkpixbufs()
|
||||||
# map = self.tree.get_colormap()
|
|
||||||
# colour = map.alloc_color("red") # light red
|
|
||||||
# colour2 = map.alloc_color("blue") # light red
|
|
||||||
# colour = map.alloc_color("#FF9999") # light red
|
|
||||||
# st = self.tree.get_style().copy()
|
|
||||||
# st.bg[gtk.STATE_NORMAL] = colour
|
|
||||||
# st.fg[gtk.STATE_NORMAL] = colour
|
|
||||||
# st.bg[gtk.STATE_ACTIVE] = colour2
|
|
||||||
# st.fg[gtk.STATE_ACTIVE] = colour2
|
|
||||||
# st.bg[gtk.STATE_INSENSITIVE] = colour
|
|
||||||
# st.bg[gtk.STATE_PRELIGHT] = colour
|
|
||||||
# st.bg[gtk.STATE_SELECTED] = colour
|
|
||||||
# st.fg[gtk.STATE_SELECTED] = colour2
|
|
||||||
# st.white = colour
|
|
||||||
# print st.bg
|
|
||||||
# print self.tree.get_property('expander-column')
|
|
||||||
# self.tree.set_style(st)
|
|
||||||
self.xml.get_widget('optionmenu').set_history(6)
|
self.xml.get_widget('optionmenu').set_history(6)
|
||||||
|
|
||||||
showOffline = self.plugin.config['showoffline']
|
showOffline = self.plugin.config['showoffline']
|
||||||
|
@ -1143,6 +1143,8 @@ class roster_Window:
|
||||||
|
|
||||||
render_text = gtk.CellRendererText()
|
render_text = gtk.CellRendererText()
|
||||||
render_text.connect('edited', self.on_cell_edited)
|
render_text.connect('edited', self.on_cell_edited)
|
||||||
|
#need gtk2.4
|
||||||
|
#render_text.connect('editing-canceled', self.on_editing_canceled)
|
||||||
col.pack_start(render_text, expand = True)
|
col.pack_start(render_text, expand = True)
|
||||||
col.add_attribute(render_text, 'text', 1)
|
col.add_attribute(render_text, 'text', 1)
|
||||||
col.add_attribute(render_text, 'editable', 4)
|
col.add_attribute(render_text, 'editable', 4)
|
||||||
|
@ -1240,12 +1242,13 @@ class plugin:
|
||||||
#('STATUS', account, status)
|
#('STATUS', account, status)
|
||||||
elif ev[0] == 'STATUS':
|
elif ev[0] == 'STATUS':
|
||||||
self.roster.on_status_changed(ev[1], ev[2])
|
self.roster.on_status_changed(ev[1], ev[2])
|
||||||
#('NOTIFY', account, (jid, status, message, resource))
|
#('NOTIFY', account, (jid, status, message, resource, priority))
|
||||||
elif ev[0] == 'NOTIFY':
|
elif ev[0] == 'NOTIFY':
|
||||||
jid = string.split(ev[2][0], '/')[0]
|
jid = string.split(ev[2][0], '/')[0]
|
||||||
resource = ev[2][3]
|
resource = ev[2][3]
|
||||||
if not resource:
|
if not resource:
|
||||||
resource = ''
|
resource = ''
|
||||||
|
priority = ev[2][4]
|
||||||
if string.find(jid, "@") <= 0:
|
if string.find(jid, "@") <= 0:
|
||||||
#It must be an agent
|
#It must be an agent
|
||||||
ji = string.replace(jid, '@', '')
|
ji = string.replace(jid, '@', '')
|
||||||
|
@ -1266,17 +1269,20 @@ class plugin:
|
||||||
if resources != [''] and (len(luser) != 1 or
|
if resources != [''] and (len(luser) != 1 or
|
||||||
luser[0].show != 'offline'):
|
luser[0].show != 'offline'):
|
||||||
user1 = user(user1.jid, user1.name, user1.groups, \
|
user1 = user(user1.jid, user1.name, user1.groups, \
|
||||||
user1.show, user1.status, user1.sub, user1.resource)
|
user1.show, user1.status, user1.sub, user1.resource, \
|
||||||
|
user1.priority)
|
||||||
luser.append(user1)
|
luser.append(user1)
|
||||||
user1.resource = resource
|
user1.resource = resource
|
||||||
user1.show = ev[2][1]
|
user1.show = ev[2][1]
|
||||||
user1.status = ev[2][2]
|
user1.status = ev[2][2]
|
||||||
|
user1.priority = priority
|
||||||
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):
|
||||||
user1 = user(ji, ji, ['Agents'], ev[2][1], \
|
user1 = user(ji, ji, ['Agents'], ev[2][1], \
|
||||||
ev[2][2], 'from', resource)
|
ev[2][2], 'from', resource)
|
||||||
self.roster.add_user_to_roster(user1, ev[1])
|
self.roster.contacts[ev[1]][ji] = [user1]
|
||||||
|
self.roster.add_user_to_roster(ji, ev[1])
|
||||||
else:
|
else:
|
||||||
#Update existing iter
|
#Update existing iter
|
||||||
for i in self.roster.get_user_iter(ji, ev[1]):
|
for i in self.roster.get_user_iter(ji, ev[1]):
|
||||||
|
@ -1296,17 +1302,19 @@ class plugin:
|
||||||
authorize_Window(self, ev[2][0], ev[2][1], ev[1])
|
authorize_Window(self, ev[2][0], ev[2][1], ev[1])
|
||||||
#('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]):
|
jid = ev[2][0]
|
||||||
u = self.roster.contacts[ev[1]][ev[2][0]][0]
|
if self.roster.contacts[ev[1]].has_key(jid):
|
||||||
|
u = self.roster.contacts[ev[1]][jid][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.get_user_iter(u.jid, ev[1]):
|
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(jid, jid, ['general'], 'online', \
|
||||||
'online', 'to', ev[2][2])
|
'online', 'to', ev[2][2], 0)
|
||||||
self.roster.add_user(user1)
|
self.roster.contacts[ev[1]][jid] = [user1]
|
||||||
warning_Window(_("You are now authorized by %s") % ev[2][0])
|
self.roster.add_user_to_roster(jid, ev[1])
|
||||||
|
warning_Window(_("You are now authorized by %s") % jid)
|
||||||
elif ev[0] == 'UNSUBSCRIBED':
|
elif ev[0] == 'UNSUBSCRIBED':
|
||||||
warning_Window(_("You are now unsubscribed by %s") % ev[2])
|
warning_Window(_("You are now unsubscribed by %s") % ev[2])
|
||||||
#TODO: change icon
|
#TODO: change icon
|
||||||
|
|
Loading…
Reference in New Issue