handle (un)subscription events as messages (don't force to popup a window) Fixes #2243

This commit is contained in:
Yann Leboulanger 2009-02-13 19:35:30 +00:00
parent 01bcfe2007
commit 95d7e157da
7 changed files with 81 additions and 15 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

View File

@ -28,11 +28,12 @@ import time
class Event: class Event:
'''Information concerning each event''' '''Information concerning each event'''
def __init__(self, type_, time_, parameters, show_in_roster = False, def __init__(self, type_, time_, parameters, show_in_roster=False,
show_in_systray = True): show_in_systray=True):
''' type_ in chat, normal, file-request, file-error, file-completed, ''' type_ in chat, normal, file-request, file-error, file-completed,
file-request-error, file-send-error, file-stopped, gc_msg, pm, file-request-error, file-send-error, file-stopped, gc_msg, pm,
printed_chat, printed_gc_msg, printed_marked_gc_msg, printed_pm printed_chat, printed_gc_msg, printed_marked_gc_msg, printed_pm,
gc-invitation, subscription_request, unsubscribed
parameters is (per type_): parameters is (per type_):
chat, normal, pm: [message, subject, kind, time, encrypted, resource, chat, normal, pm: [message, subject, kind, time, encrypted, resource,
msg_id] msg_id]
@ -41,7 +42,11 @@ class Event:
gc_msg: None gc_msg: None
printed_chat: control printed_chat: control
printed_*: None printed_*: None
messages that are already printed in chat, but not read''' messages that are already printed in chat, but not read
gc-invitation: [room_jid, reason, password, is_continued]
subscription_request: [text, nick]
unsubscribed: contact
'''
self.type_ = type_ self.type_ = type_
self.time_ = time_ self.time_ = time_
self.parameters = parameters self.parameters = parameters

View File

@ -1644,6 +1644,9 @@ class SubscriptionRequestWindow:
def on_deny_button_clicked(self, widget): def on_deny_button_clicked(self, widget):
'''refuse the request''' '''refuse the request'''
gajim.connections[self.account].refuse_authorization(self.jid) gajim.connections[self.account].refuse_authorization(self.jid)
contact = gajim.contacts.get_contact(self.account, self.jid)
if contact and _('Not in Roster') in contact.get_shown_groups():
gajim.interface.roster.remove_contact(self.jid, self.account)
self.window.destroy() self.window.destroy()
def on_actions_button_clicked(self, widget): def on_actions_button_clicked(self, widget):

View File

@ -959,10 +959,26 @@ class Interface:
def handle_event_subscribe(self, account, array): def handle_event_subscribe(self, account, array):
#('SUBSCRIBE', account, (jid, text, user_nick)) user_nick is JEP-0172 #('SUBSCRIBE', account, (jid, text, user_nick)) user_nick is JEP-0172
dialogs.SubscriptionRequestWindow(array[0], array[1], account, array[2])
if self.remote_ctrl: if self.remote_ctrl:
self.remote_ctrl.raise_signal('Subscribe', (account, array)) self.remote_ctrl.raise_signal('Subscribe', (account, array))
jid = array[0]
text = array[1]
nick = array[2]
if helpers.allow_popup_window(account) or not self.systray_enabled:
dialogs.SubscriptionRequestWindow(jid, text, account, nick)
return
self.add_event(account, jid, 'subscription_request', (text, nick))
if helpers.allow_showing_notification(account):
path = os.path.join(gajim.DATA_DIR, 'pixmaps', 'events',
'subscription_request.png')
path = gtkgui_helpers.get_path_to_generic_or_avatar(path)
event_type = _('Subscription request')
notify.popup(event_type, jid, account, 'subscription_request', path,
event_type, jid)
def handle_event_subscribed(self, account, array): def handle_event_subscribed(self, account, array):
#('SUBSCRIBED', account, (jid, resource)) #('SUBSCRIBED', account, (jid, resource))
jid = array[0] jid = array[0]
@ -992,7 +1008,20 @@ class Interface:
if self.remote_ctrl: if self.remote_ctrl:
self.remote_ctrl.raise_signal('Subscribed', (account, array)) self.remote_ctrl.raise_signal('Subscribed', (account, array))
def show_unsubscribed_dialog(self, account, contact):
def on_yes(is_checked, list_):
self.roster.on_req_usub(None, list_)
list_ = [(contact, account)]
dialogs.YesNoDialog(
_('Contact "%s" removed subscription from you') % contact.jid,
_('You will always see him or her as offline.\nDo you want to '
'remove him or her from your contact list?'),
on_response_yes=(on_yes, list_))
# FIXME: Per RFC 3921, we can "deny" ack as well, but the GUI does
# not show deny
def handle_event_unsubscribed(self, account, jid): def handle_event_unsubscribed(self, account, jid):
#('UNSUBSCRIBED', account, jid)
gajim.connections[account].ack_unsubscribed(jid) gajim.connections[account].ack_unsubscribed(jid)
if self.remote_ctrl: if self.remote_ctrl:
self.remote_ctrl.raise_signal('Unsubscribed', (account, jid)) self.remote_ctrl.raise_signal('Unsubscribed', (account, jid))
@ -1000,14 +1029,19 @@ class Interface:
contact = gajim.contacts.get_first_contact_from_jid(account, jid) contact = gajim.contacts.get_first_contact_from_jid(account, jid)
if not contact: if not contact:
return return
def on_yes(is_checked, list_):
self.roster.on_req_usub(None, list_) if helpers.allow_popup_window(account) or not self.systray_enabled:
list_ = [(contact, account)] self.show_unsubscribed_dialog(account, contact)
dialogs.YesNoDialog(
_('Contact "%s" removed subscription from you') % jid, self.add_event(account, jid, 'unsubscribed', contact)
_('You will always see him or her as offline.\nDo you want to remove him or her from your contact list?'),
on_response_yes=(on_yes, list_)) if helpers.allow_showing_notification(account):
# FIXME: Per RFC 3921, we can "deny" ack as well, but the GUI does not show deny path = os.path.join(gajim.DATA_DIR, 'pixmaps', 'events',
'unsubscribed.png')
path = gtkgui_helpers.get_path_to_generic_or_avatar(path)
event_type = _('Unsubscribed')
notify.popup(event_type, jid, account, 'unsubscribed', path,
event_type, jid)
def handle_event_agent_info_error(self, account, agent): def handle_event_agent_info_error(self, account, agent):
#('AGENT_ERROR_INFO', account, (agent)) #('AGENT_ERROR_INFO', account, (agent))
@ -2256,8 +2290,8 @@ class Interface:
show_in_roster = notify.get_show_in_roster(event_type, account, jid) show_in_roster = notify.get_show_in_roster(event_type, account, jid)
show_in_systray = notify.get_show_in_systray(event_type, account, jid) show_in_systray = notify.get_show_in_systray(event_type, account, jid)
event = gajim.events.create_event(type_, event_args, event = gajim.events.create_event(type_, event_args,
show_in_roster = show_in_roster, show_in_roster=show_in_roster,
show_in_systray = show_in_systray) show_in_systray=show_in_systray)
gajim.events.add_event(account, jid, event) gajim.events.add_event(account, jid, event)
self.roster.show_title() self.roster.show_title()
@ -2389,6 +2423,18 @@ class Interface:
data[1], data[3]) data[1], data[3])
gajim.events.remove_events(account, jid, event) gajim.events.remove_events(account, jid, event)
self.roster.draw_contact(jid, account) self.roster.draw_contact(jid, account)
elif type_ == 'subscription_request':
event = gajim.events.get_first_event(account, jid, type_)
data = event.parameters
dialogs.SubscriptionRequestWindow(jid, data[0], account, data[1])
gajim.events.remove_events(account, jid, event)
self.roster.draw_contact(jid, account)
elif type_ == 'unsubscribed':
event = gajim.events.get_first_event(account, jid, type_)
contact = event.parameters
self.show_unsubscribed_dialog(account, contact)
gajim.events.remove_events(account, jid, event)
self.roster.draw_contact(jid, account)
if w: if w:
w.set_active_tab(ctrl) w.set_active_tab(ctrl)
w.window.window.focus() w.window.window.focus()

View File

@ -492,6 +492,10 @@ class DesktopNotification:
ntype = 'presence.status' ntype = 'presence.status'
elif event_type == _('Connection Failed'): elif event_type == _('Connection Failed'):
ntype = 'connection.failed' ntype = 'connection.failed'
elif event_type == _('Subscription request'):
ntype = 'subscription.request'
elif event_type == _('Unsubscribed'):
ntype = 'unsubscribed'
else: else:
# default failsafe values # default failsafe values
self.path_to_image = os.path.abspath( self.path_to_image = os.path.abspath(

View File

@ -1832,6 +1832,14 @@ class RosterWindow:
data[1]) data[1])
gajim.events.remove_events(account, jid, event) gajim.events.remove_events(account, jid, event)
return True return True
elif event.type_ == 'subscription_request':
dialogs.SubscriptionRequestWindow(jid, data[0], account, data[1])
gajim.events.remove_events(account, jid, event)
return True
elif event.type_ == 'unsubscribed':
gajim.interface.show_unsubscribed_dialog(account, data)
gajim.events.remove_events(account, jid, event)
return True
return False return False
################################################################################ ################################################################################