MUC support ! (privileges in chatrooms)
This commit is contained in:
parent
c56fb5d532
commit
fc7ece41ee
4 changed files with 335 additions and 27 deletions
|
@ -125,6 +125,7 @@ NS_XEXPIRE = "jabber:x:expire" # JEP-0023
|
||||||
NS_XENCRYPTED = "jabber:x:encrypted" # JEP-0027
|
NS_XENCRYPTED = "jabber:x:encrypted" # JEP-0027
|
||||||
NS_XSIGNED = "jabber:x:signed" # JEP-0027
|
NS_XSIGNED = "jabber:x:signed" # JEP-0027
|
||||||
NS_P_MUC = _NS_PROTOCOL + "/muc" # JEP-0045
|
NS_P_MUC = _NS_PROTOCOL + "/muc" # JEP-0045
|
||||||
|
NS_P_MUC_ADMIN = NS_P_MUC + "#admin" # JEP-0045
|
||||||
NS_VCARD = "vcard-temp" # JEP-0054
|
NS_VCARD = "vcard-temp" # JEP-0054
|
||||||
|
|
||||||
|
|
||||||
|
@ -716,7 +717,7 @@ class Client(Connection):
|
||||||
For identity: category, name is mandatory, type is optional.
|
For identity: category, name is mandatory, type is optional.
|
||||||
For feature: var is mandatory"""
|
For feature: var is mandatory"""
|
||||||
identities , features = [] , []
|
identities , features = [] , []
|
||||||
disco = self._discover(NS_P_DISC_INFO,jid,node)
|
disco = self._discover(NS_P_DISC_INFO,jid,node)
|
||||||
if disco:
|
if disco:
|
||||||
for i in disco:
|
for i in disco:
|
||||||
if i.getName()=='identity': identities.append(i.attrs)
|
if i.getName()=='identity': identities.append(i.attrs)
|
||||||
|
@ -726,19 +727,22 @@ class Client(Connection):
|
||||||
def browseAgent(self,jid,node=None):
|
def browseAgent(self,jid,node=None):
|
||||||
identities, features, items = [], [], []
|
identities, features, items = [], [], []
|
||||||
iq=Iq(to=jid,type='get',query=NS_BROWSE)
|
iq=Iq(to=jid,type='get',query=NS_BROWSE)
|
||||||
rep=self.SendAndWaitForResponse(iq)
|
rep=self.SendAndWaitForResponse(iq)
|
||||||
if not rep:
|
if not rep:
|
||||||
return identities, features, items
|
return identities, features, items
|
||||||
q = rep.getTag('service')
|
q = rep.getTag('service')
|
||||||
identities = [q.attrs]
|
if q:
|
||||||
|
identities = [q.attrs]
|
||||||
|
else:
|
||||||
|
identities = []
|
||||||
if not q:
|
if not q:
|
||||||
return identities, features, items
|
return identities, features, items
|
||||||
for node in q.kids:
|
for node in q.kids:
|
||||||
if node.getName() == 'ns':
|
if node.getName() == 'ns':
|
||||||
features.append(node.getData())
|
features.append(node.getData())
|
||||||
else:
|
else:
|
||||||
infos = node.attrs
|
infos = node.attrs
|
||||||
infos['category'] = node.getName()
|
infos['category'] = node.getName()
|
||||||
items.append(node.attrs)
|
items.append(node.attrs)
|
||||||
return identities, features, items
|
return identities, features, items
|
||||||
|
|
||||||
|
@ -1018,6 +1022,80 @@ class Presence(Protocol):
|
||||||
try: return self.getTag('priority').getData()
|
try: return self.getTag('priority').getData()
|
||||||
except: return None
|
except: return None
|
||||||
|
|
||||||
|
def getRole(self):
|
||||||
|
"""Returns the presence role (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if child.getName() == 'item':
|
||||||
|
try: return child.getAttr('role')
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
|
def getAffiliation(self):
|
||||||
|
"""Returns the presence affiliation (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if child.getName() == 'item':
|
||||||
|
try: return child.getAttr('affiliation')
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
|
def getJid(self):
|
||||||
|
"""Returns the presence jid (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if child.getName() == 'item':
|
||||||
|
try: return child.getAttr('jid')
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
|
def getReason(self):
|
||||||
|
"""Returns the reason of the presence (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if not child.getName() == 'item':
|
||||||
|
continue
|
||||||
|
for cchild in child.getChildren():
|
||||||
|
if not cchild.getName() == 'reason':
|
||||||
|
continue
|
||||||
|
try: return cchild.getData()
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
|
def getActor(self):
|
||||||
|
"""Returns the reason of the presence (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if not child.getName() == 'item':
|
||||||
|
continue
|
||||||
|
for cchild in child.getChildren():
|
||||||
|
if not cchild.getName() == 'actor':
|
||||||
|
continue
|
||||||
|
try: return cchild.getAttr('jid')
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
|
def getStatusCode(self):
|
||||||
|
"""Returns the status code of the presence (for groupchat)"""
|
||||||
|
try: xtags = self.getTags('x')
|
||||||
|
except: return None
|
||||||
|
for xtag in xtags:
|
||||||
|
for child in xtag.getChildren():
|
||||||
|
if child.getName() == 'status':
|
||||||
|
try: return child.getAttr('code')
|
||||||
|
except: pass
|
||||||
|
return None
|
||||||
|
|
||||||
def setShow(self,val):
|
def setShow(self,val):
|
||||||
"""Sets the presence show"""
|
"""Sets the presence show"""
|
||||||
show = self.getTag('show')
|
show = self.getTag('show')
|
||||||
|
|
14
core/core.py
14
core/core.py
|
@ -204,11 +204,15 @@ class GajimCore:
|
||||||
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(), prio))
|
prs.getFrom().getResource(), prio, prs.getRole(), \
|
||||||
|
prs.getAffiliation(), prs.getJid(), prs.getReason(), \
|
||||||
|
prs.getActor(), prs.getStatusCode()))
|
||||||
elif typ == 'unavailable':
|
elif typ == '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(), prio))
|
prs.getFrom().getResource(), prio, prs.getRole(), \
|
||||||
|
prs.getAffiliation(), prs.getJid(), prs.getReason(), \
|
||||||
|
prs.getActor(), prs.getStatusCode()))
|
||||||
elif typ == 'subscribe':
|
elif typ == '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 \
|
||||||
|
@ -217,7 +221,8 @@ 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(), prio))
|
prs.getFrom().getResource(), prio, None, None, None, None, \
|
||||||
|
None, None))
|
||||||
else:
|
else:
|
||||||
txt = prs.getStatus()
|
txt = prs.getStatus()
|
||||||
if not txt:
|
if not txt:
|
||||||
|
@ -267,7 +272,8 @@ class GajimCore:
|
||||||
else:
|
else:
|
||||||
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(), prio))
|
prs.getFrom().getResource(), prio, None, None, None, None, None,\
|
||||||
|
None))
|
||||||
# END presenceCB
|
# END presenceCB
|
||||||
|
|
||||||
def disconnectedCB(self, con):
|
def disconnectedCB(self, con):
|
||||||
|
|
|
@ -7297,6 +7297,11 @@ when NOT online</property>
|
||||||
<property name="rules_hint">False</property>
|
<property name="rules_hint">False</property>
|
||||||
<property name="reorderable">True</property>
|
<property name="reorderable">True</property>
|
||||||
<property name="enable_search">False</property>
|
<property name="enable_search">False</property>
|
||||||
|
<signal name="row_activated" handler="on_row_activated" last_modification_time="Mon, 20 Sep 2004 13:30:37 GMT"/>
|
||||||
|
<signal name="row_collapsed" handler="on_row_collapsed" last_modification_time="Mon, 20 Sep 2004 13:30:45 GMT"/>
|
||||||
|
<signal name="row_expanded" handler="on_row_expanded" last_modification_time="Mon, 20 Sep 2004 13:30:52 GMT"/>
|
||||||
|
<signal name="button_press_event" handler="on_treeview_event" last_modification_time="Mon, 20 Sep 2004 16:22:47 GMT"/>
|
||||||
|
<signal name="key_release_event" handler="on_treeview_event" last_modification_time="Mon, 20 Sep 2004 16:23:36 GMT"/>
|
||||||
</widget>
|
</widget>
|
||||||
</child>
|
</child>
|
||||||
</widget>
|
</widget>
|
||||||
|
|
|
@ -309,44 +309,90 @@ class gc:
|
||||||
"""When Cancel button is clicked"""
|
"""When Cancel button is clicked"""
|
||||||
widget.get_toplevel().destroy()
|
widget.get_toplevel().destroy()
|
||||||
|
|
||||||
def get_user_iter(self, nick):
|
def get_role_iter(self, name):
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
|
fin = False
|
||||||
iter = model.get_iter_root()
|
iter = model.get_iter_root()
|
||||||
if not iter:
|
if not iter:
|
||||||
return None
|
return None
|
||||||
while iter:
|
while not fin:
|
||||||
if nick == model.get_value(iter, 1):
|
account_name = model.get_value(iter, 1)
|
||||||
|
if name == account_name:
|
||||||
return iter
|
return iter
|
||||||
iter = model.iter_next(iter)
|
iter = model.iter_next(iter)
|
||||||
|
if not iter:
|
||||||
|
fin = True
|
||||||
|
return None
|
||||||
|
|
||||||
|
def get_user_iter(self, jid):
|
||||||
|
model = self.tree.get_model()
|
||||||
|
fin = False
|
||||||
|
role = model.get_iter_root()
|
||||||
|
if not role:
|
||||||
|
return None
|
||||||
|
while not fin:
|
||||||
|
fin2 = False
|
||||||
|
user = model.iter_children(role)
|
||||||
|
if not user:
|
||||||
|
fin2=True
|
||||||
|
while not fin2:
|
||||||
|
if jid == model.get_value(user, 1):
|
||||||
|
return user
|
||||||
|
user = model.iter_next(user)
|
||||||
|
if not user:
|
||||||
|
fin2 = True
|
||||||
|
role = model.iter_next(role)
|
||||||
|
if not role:
|
||||||
|
fin = True
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def remove_user(self, nick):
|
def remove_user(self, nick):
|
||||||
"""Remove a user from the roster"""
|
"""Remove a user from the roster"""
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
iter = self.get_user_iter(nick)
|
iter = self.get_user_iter(nick)
|
||||||
|
parent_iter = model.iter_parent(iter)
|
||||||
model.remove(iter)
|
model.remove(iter)
|
||||||
|
if model.iter_n_children(parent_iter) == 0:
|
||||||
|
model.remove(parent_iter)
|
||||||
|
|
||||||
def add_user_to_roster(self, nick, show):
|
def add_user_to_roster(self, nick, show, role):
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
img = self.plugin.roster.pixbufs[show]
|
img = self.plugin.roster.pixbufs[show]
|
||||||
return model.append(None, (img, nick))
|
role_iter = self.get_role_iter(role)
|
||||||
|
if not role_iter:
|
||||||
|
role_iter = model.append(None, (self.plugin.roster.pixbufs['closed']\
|
||||||
|
, role))
|
||||||
|
iter = model.append(role_iter, (img, nick))
|
||||||
|
self.tree.expand_row((model.get_path(role_iter)), False)
|
||||||
|
return iter
|
||||||
|
|
||||||
|
def get_role(self, jid_iter):
|
||||||
|
model = self.tree.get_model()
|
||||||
|
path = model.get_path(jid_iter)[0]
|
||||||
|
iter = model.get_iter(path)
|
||||||
|
return model.get_value(iter, 1)
|
||||||
|
|
||||||
def chg_user_status(self, nick, show, status, account):
|
def chg_user_status(self, nick, show, status, role, affiliation, jid, \
|
||||||
|
reason, actor, statusCode, account):
|
||||||
"""When a user change his status"""
|
"""When a user change his status"""
|
||||||
model = self.tree.get_model()
|
model = self.tree.get_model()
|
||||||
if show == 'offline' or show == 'error':
|
if show == 'offline' or show == 'error':
|
||||||
|
if statusCode == '307':
|
||||||
|
self.print_conversation(_("%s has been kicked by %s: %s") % (nick, \
|
||||||
|
actor, reason))
|
||||||
self.remove_user(nick)
|
self.remove_user(nick)
|
||||||
else:
|
else:
|
||||||
iter = self.get_user_iter(nick)
|
iter = self.get_user_iter(nick)
|
||||||
if not iter:
|
if not iter:
|
||||||
iter = self.add_user_to_roster(nick, show)
|
iter = self.add_user_to_roster(nick, show, role)
|
||||||
else:
|
else:
|
||||||
img = self.plugin.roster.pixbufs[show]
|
actual_role = self.get_role(iter)
|
||||||
model.set_value(iter, 0, img)
|
if role != actual_role:
|
||||||
# u = self.contacts[account][user.jid]
|
self.remove_user(nick)
|
||||||
# u.show = show
|
self.add_user_to_roster(nick, show, role)
|
||||||
# u.status = status
|
else:
|
||||||
# self.redraw_jid(user.jid, account)
|
img = self.plugin.roster.pixbufs[show]
|
||||||
|
model.set_value(iter, 0, img)
|
||||||
|
|
||||||
def on_msg_key_press_event(self, widget, event):
|
def on_msg_key_press_event(self, widget, event):
|
||||||
"""When a key is pressed :
|
"""When a key is pressed :
|
||||||
|
@ -393,10 +439,175 @@ class gc:
|
||||||
#scroll to the end of the textview
|
#scroll to the end of the textview
|
||||||
conversation.scroll_to_mark(buffer.get_mark('end'), 0.1, 0, 0, 0)
|
conversation.scroll_to_mark(buffer.get_mark('end'), 0.1, 0, 0, 0)
|
||||||
|
|
||||||
|
def kick(self, widget, room_jid, nick):
|
||||||
|
"""kick a user"""
|
||||||
|
self.plugin.send('SET_ROLE', self.account, (room_jid, nick, 'none'))
|
||||||
|
|
||||||
|
def grant_voice(self, widget, room_jid, nick):
|
||||||
|
"""grant voice privilege to a user"""
|
||||||
|
self.plugin.send('SET_ROLE', self.account, (room_jid, nick, \
|
||||||
|
'participant'))
|
||||||
|
|
||||||
|
def revoke_voice(self, widget, room_jid, nick):
|
||||||
|
"""revoke voice privilege to a user"""
|
||||||
|
self.plugin.send('SET_ROLE', self.account, (room_jid, nick, 'visitor'))
|
||||||
|
|
||||||
|
def grant_moderator(self, widget, room_jid, nick):
|
||||||
|
"""grant moderator privilege to a user"""
|
||||||
|
self.plugin.send('SET_ROLE', self.account, (room_jid, nick, 'moderator'))
|
||||||
|
|
||||||
|
def revoke_moderator(self, widget, room_jid, nick):
|
||||||
|
"""revoke moderator privilege to a user"""
|
||||||
|
self.plugin.send('SET_ROLE', self.account, (room_jid, nick, \
|
||||||
|
'participant'))
|
||||||
|
|
||||||
|
def ban(self, widget, room_jid, nick):
|
||||||
|
"""ban a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'outcast'))
|
||||||
|
|
||||||
|
def grant_membership(self, widget, room_jid, nick):
|
||||||
|
"""grant membership privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'member'))
|
||||||
|
|
||||||
|
def revoke_membership(self, widget, room_jid, nick):
|
||||||
|
"""revoke membership privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'none'))
|
||||||
|
|
||||||
|
def grant_admin(self, widget, room_jid, nick):
|
||||||
|
"""grant administrative privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'admin'))
|
||||||
|
|
||||||
|
def revoke_admin(self, widget, room_jid, nick):
|
||||||
|
"""revoke administrative privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'member'))
|
||||||
|
|
||||||
|
def grant_owner(self, widget, room_jid, nick):
|
||||||
|
"""grant owner privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'owner'))
|
||||||
|
|
||||||
|
def revoke_owner(self, widget, room_jid, nick):
|
||||||
|
"""revoke owner privilege to a user"""
|
||||||
|
self.plugin.send('SET_AFFILIATION', self.account, (room_jid, nick, \
|
||||||
|
'admin'))
|
||||||
|
|
||||||
|
def mk_menu(self, event, iter):
|
||||||
|
"""Make user's popup menu"""
|
||||||
|
model = self.tree.get_model()
|
||||||
|
nick = model.get_value(iter, 1)
|
||||||
|
# jid = model.get_value(iter, 3)
|
||||||
|
# path = model.get_path(iter)
|
||||||
|
# user = self.contacts[account][jid][0]
|
||||||
|
|
||||||
|
menu = gtk.Menu()
|
||||||
|
item = gtk.MenuItem(_("MUC"))
|
||||||
|
menu.append(item)
|
||||||
|
|
||||||
|
menu_sub = gtk.Menu()
|
||||||
|
item.set_submenu(menu_sub)
|
||||||
|
item = gtk.MenuItem(_("Kick"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.kick, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Grant voice"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.grant_voice, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Revoke voice"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.revoke_voice, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Grant moderator"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.grant_moderator, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Revoke moderator"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.revoke_moderator, self.jid, nick)
|
||||||
|
|
||||||
|
item = gtk.MenuItem()
|
||||||
|
menu_sub.append(item)
|
||||||
|
|
||||||
|
item = gtk.MenuItem(_("Ban"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.ban, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Grant membership"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.grant_membership, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Revoke membership"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.revoke_membership, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Grant admin"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.grant_admin, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Revoke admin"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.revoke_admin, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Grant owner"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.grant_owner, self.jid, nick)
|
||||||
|
item = gtk.MenuItem(_("Revoke owner"))
|
||||||
|
menu_sub.append(item)
|
||||||
|
item.connect("activate", self.revoke_owner, self.jid, nick)
|
||||||
|
|
||||||
|
menu.popup(None, None, None, event.button, event.time)
|
||||||
|
menu.show_all()
|
||||||
|
menu.reposition()
|
||||||
|
|
||||||
def on_focus(self, widget, event):
|
def on_focus(self, widget, event):
|
||||||
"""When window get focus"""
|
"""When window get focus"""
|
||||||
self.plugin.systray.remove_jid(self.jid, self.account)
|
self.plugin.systray.remove_jid(self.jid, self.account)
|
||||||
|
|
||||||
|
def on_treeview_event(self, widget, event):
|
||||||
|
"""popup user's group's or agent menu"""
|
||||||
|
if event.type == gtk.gdk.BUTTON_PRESS:
|
||||||
|
if event.button == 3:
|
||||||
|
try:
|
||||||
|
path, column, x, y = self.tree.get_path_at_pos(int(event.x), \
|
||||||
|
int(event.y))
|
||||||
|
except TypeError:
|
||||||
|
self.tree.get_selection().unselect_all()
|
||||||
|
return gtk.FALSE
|
||||||
|
model = self.tree.get_model()
|
||||||
|
iter = model.get_iter(path)
|
||||||
|
if len(path) == 2:
|
||||||
|
self.mk_menu(event, iter)
|
||||||
|
return gtk.TRUE
|
||||||
|
if event.button == 1:
|
||||||
|
try:
|
||||||
|
path, column, x, y = self.tree.get_path_at_pos(int(event.x), \
|
||||||
|
int(event.y))
|
||||||
|
except TypeError:
|
||||||
|
self.tree.get_selection().unselect_all()
|
||||||
|
if event.type == gtk.gdk.KEY_RELEASE:
|
||||||
|
if event.keyval == gtk.keysyms.Escape:
|
||||||
|
self.tree.get_selection().unselect_all()
|
||||||
|
return gtk.FALSE
|
||||||
|
|
||||||
|
def on_row_activated(self, widget, path, col=0):
|
||||||
|
"""When an iter is dubble clicked :
|
||||||
|
open the chat window"""
|
||||||
|
model = self.tree.get_model()
|
||||||
|
iter = model.get_iter(path)
|
||||||
|
if len(path) == 1:
|
||||||
|
if (self.tree.row_expanded(path)):
|
||||||
|
self.tree.collapse_row(path)
|
||||||
|
else:
|
||||||
|
self.tree.expand_row(path, False)
|
||||||
|
|
||||||
|
def on_row_expanded(self, widget, iter, path):
|
||||||
|
"""When a row is expanded :
|
||||||
|
change the icon of the arrow"""
|
||||||
|
model = self.tree.get_model()
|
||||||
|
model.set_value(iter, 0, self.plugin.roster.pixbufs['opened'])
|
||||||
|
|
||||||
|
def on_row_collapsed(self, widget, iter, path):
|
||||||
|
"""When a row is collapsed :
|
||||||
|
change the icon of the arrow"""
|
||||||
|
model = self.tree.get_model()
|
||||||
|
model.set_value(iter, 0, self.plugin.roster.pixbufs['closed'])
|
||||||
|
|
||||||
def __init__(self, jid, nick, plugin, account):
|
def __init__(self, jid, nick, plugin, account):
|
||||||
self.jid = jid
|
self.jid = jid
|
||||||
self.nick = nick
|
self.nick = nick
|
||||||
|
@ -442,6 +653,10 @@ class gc:
|
||||||
self.xml.signal_connect('on_focus', self.on_focus)
|
self.xml.signal_connect('on_focus', self.on_focus)
|
||||||
self.xml.signal_connect('on_msg_key_press_event', \
|
self.xml.signal_connect('on_msg_key_press_event', \
|
||||||
self.on_msg_key_press_event)
|
self.on_msg_key_press_event)
|
||||||
|
self.xml.signal_connect('on_treeview_event', self.on_treeview_event)
|
||||||
|
self.xml.signal_connect('on_row_activated', self.on_row_activated)
|
||||||
|
self.xml.signal_connect('on_row_expanded', self.on_row_expanded)
|
||||||
|
self.xml.signal_connect('on_row_collapsed', self.on_row_collapsed)
|
||||||
|
|
||||||
class log_Window:
|
class log_Window:
|
||||||
"""Class for bowser agent window :
|
"""Class for bowser agent window :
|
||||||
|
@ -1305,7 +1520,8 @@ 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][0], 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 :
|
||||||
|
@ -1375,7 +1591,8 @@ class roster_Window:
|
||||||
"""When browse agent is selected :
|
"""When browse agent is selected :
|
||||||
Call browse class"""
|
Call browse class"""
|
||||||
if not self.plugin.windows[account].has_key('browser'):
|
if not self.plugin.windows[account].has_key('browser'):
|
||||||
self.plugin.windows[account]['browser'] = browseAgent_Window(self.plugin, account)
|
self.plugin.windows[account]['browser'] = \
|
||||||
|
browseAgent_Window(self.plugin, account)
|
||||||
|
|
||||||
def mkpixbufs(self):
|
def mkpixbufs(self):
|
||||||
"""initialise pixbufs array"""
|
"""initialise pixbufs array"""
|
||||||
|
@ -1829,7 +2046,8 @@ class plugin:
|
||||||
self.roster.on_status_changed(account, status)
|
self.roster.on_status_changed(account, status)
|
||||||
|
|
||||||
def handle_event_notify(self, account, array):
|
def handle_event_notify(self, account, array):
|
||||||
#('NOTIFY', account, (jid, status, message, resource, priority))
|
#('NOTIFY', account, (jid, status, message, resource, priority, role, \
|
||||||
|
#affiliation, real_jid, reason, actor, statusCode))
|
||||||
jid = string.split(array[0], '/')[0]
|
jid = string.split(array[0], '/')[0]
|
||||||
resource = array[3]
|
resource = array[3]
|
||||||
if not resource:
|
if not resource:
|
||||||
|
@ -1873,7 +2091,8 @@ class plugin:
|
||||||
elif self.windows[account]['gc'].has_key(ji):
|
elif self.windows[account]['gc'].has_key(ji):
|
||||||
#it is a groupchat presence
|
#it is a groupchat presence
|
||||||
self.windows[account]['gc'][ji].chg_user_status(resource, array[1],\
|
self.windows[account]['gc'][ji].chg_user_status(resource, array[1],\
|
||||||
array[2], account)
|
array[2], array[5], array[6], array[7], array[8], array[9], \
|
||||||
|
array[10], account)
|
||||||
|
|
||||||
def handle_event_msg(self, account, array):
|
def handle_event_msg(self, account, array):
|
||||||
#('MSG', account, (user, msg))
|
#('MSG', account, (user, msg))
|
||||||
|
|
Loading…
Add table
Reference in a new issue