- rename error-received event to iq-error-received

- move some code from generate() function to the correct handler for PresenceEvent
This commit is contained in:
Yann Leboulanger 2010-10-04 13:51:42 +02:00
parent e2c270a67c
commit 4d14935987
3 changed files with 59 additions and 68 deletions

View File

@ -895,10 +895,10 @@ class ConnectionHandlersBase:
# keep track of sessions this connection has with other JIDs # keep track of sessions this connection has with other JIDs
self.sessions = {} self.sessions = {}
gajim.ged.register_event_handler('error-received', ged.CORE, gajim.ged.register_event_handler('iq-error-received', ged.CORE,
self._nec_error_received) self._nec_iq_error_received)
def _nec_error_received(self, obj): def _nec_iq_error_received(self, obj):
if obj.conn.name != self.name: if obj.conn.name != self.name:
return return
if obj.id_ in self.last_ids: if obj.id_ in self.last_ids:
@ -1108,8 +1108,8 @@ ConnectionJingle, ConnectionIBBytestream):
ged.CORE, self._nec_private_storate_rosternotes_received) ged.CORE, self._nec_private_storate_rosternotes_received)
gajim.ged.register_event_handler('roster-received', ged.CORE, gajim.ged.register_event_handler('roster-received', ged.CORE,
self._nec_roster_received) self._nec_roster_received)
gajim.ged.register_event_handler('error-received', ged.CORE, gajim.ged.register_event_handler('iq-error-received', ged.CORE,
self._nec_error_received) self._nec_iq_error_received)
gajim.ged.register_event_handler('gmail-new-mail-received', ged.CORE, gajim.ged.register_event_handler('gmail-new-mail-received', ged.CORE,
self._nec_gmail_new_mail_received) self._nec_gmail_new_mail_received)
gajim.ged.register_event_handler('ping-received', ged.CORE, gajim.ged.register_event_handler('ping-received', ged.CORE,
@ -1156,10 +1156,10 @@ ConnectionJingle, ConnectionIBBytestream):
def _ErrorCB(self, con, iq_obj): def _ErrorCB(self, con, iq_obj):
log.debug('ErrorCB') log.debug('ErrorCB')
gajim.nec.push_incoming_event(ErrorReceivedEvent(None, conn=self, gajim.nec.push_incoming_event(IqErrorReceivedEvent(None, conn=self,
iq_obj=iq_obj)) iq_obj=iq_obj))
def _nec_error_received(self, obj): def _nec_iq_error_received(self, obj):
if obj.conn.name != self.name: if obj.conn.name != self.name:
return return
if obj.id_ in self.version_ids: if obj.id_ in self.version_ids:
@ -1879,6 +1879,47 @@ ConnectionJingle, ConnectionIBBytestream):
sess.terminate_e2e() sess.terminate_e2e()
self.delete_session(jid, sess.thread_id) self.delete_session(jid, sess.thread_id)
if obj.ptype == 'unavailable':
for jid in (obj.jid, obj.fjid):
if jid not in self.sessions:
continue
# automatically terminate sessions that they haven't sent a
# thread ID in, only if other part support thread ID
for sess in self.sessions[jid].values():
if not sess.received_thread_id:
contact = gajim.contacts.get_contact(self.name, jid)
if contact and (contact.supports(xmpp.NS_SSN) or \
contact.supports(xmpp.NS_ESESSION)):
sess.terminate()
del self.sessions[jid][sess.thread_id]
if obj.avatar_sha is not None and obj.ptype != 'error':
if obj.jid not in self.vcard_shas:
cached_vcard = self.get_cached_vcard(obj.jid)
if cached_vcard and 'PHOTO' in cached_vcard and \
'SHA' in cached_vcard['PHOTO']:
self.vcard_shas[obj.jid] = cached_vcard['PHOTO']['SHA']
else:
self.vcard_shas[obj.jid] = ''
if obj.avatar_sha != self.vcard_shas[obj.jid]:
# avatar has been updated
self.request_vcard(obj.jid)
if gajim.config.get('log_contact_status_changes') and \
gajim.config.should_log(self.name, obj.jid):
try:
gajim.logger.write('status', obj.jid, obj.status, obj.show)
except exceptions.PysqliteOperationalError, e:
self.dispatch('DB_ERROR', (_('Disk Write Error'), str(e)))
except exceptions.DatabaseMalformed:
pritext = _('Database Error')
sectext = _('The database file (%s) cannot be read. Try to '
'repair it (see '
'http://trac.gajim.org/wiki/DatabaseBackup) or remove '
'it (all history will be lost).') % LOG_DB_PATH
self.dispatch('DB_ERROR', (pritext, sectext))
our_jid = gajim.get_jid_from_account(self.name)
def _nec_subscribe_presence_received(self, obj): def _nec_subscribe_presence_received(self, obj):
account = obj.conn.name account = obj.conn.name
if account != self.name: if account != self.name:

View File

@ -559,8 +559,8 @@ class SearchResultReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
self.data.append(f) self.data.append(f)
return True return True
class ErrorReceivedEvent(nec.NetworkIncomingEvent, HelperEvent): class IqErrorReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
name = 'error-received' name = 'iq-error-received'
base_network_events = [] base_network_events = []
def generate(self): def generate(self):
@ -700,6 +700,9 @@ class PresenceReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
self.keyID = helpers.prepare_and_validate_gpg_keyID(self.conn.name, self.keyID = helpers.prepare_and_validate_gpg_keyID(self.conn.name,
self.jid, self.keyID) self.jid, self.keyID)
self.errcode = self.iq_obj.getErrorCode()
self.errmsg = self.iq_obj.getErrorMsg()
if self.is_gc: if self.is_gc:
gajim.nec.push_incoming_event(GcPresenceReceivedEvent(None, gajim.nec.push_incoming_event(GcPresenceReceivedEvent(None,
conn=self.conn, iq_obj=self.iq_obj, presence_obj=self)) conn=self.conn, iq_obj=self.iq_obj, presence_obj=self))
@ -718,65 +721,12 @@ class PresenceReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
gajim.nec.push_incoming_event(UnsubscribedPresenceReceivedEvent( gajim.nec.push_incoming_event(UnsubscribedPresenceReceivedEvent(
None, conn=self.conn, iq_obj=self.iq_obj, presence_obj=self)) None, conn=self.conn, iq_obj=self.iq_obj, presence_obj=self))
elif self.ptype == 'error': elif self.ptype == 'error':
errmsg = self.iq_obj.getError() if self.errcode != '409': # conflict # See #5120
errcode = self.iq_obj.getErrorCode()
if errcode != '502': # Internal Timeout:
# print in the window the error
self.conn.dispatch('ERROR_ANSWER', ('', self.jid, errmsg, errcode))
if errcode != '409': # conflict # See #5120
self.show = 'error' self.show = 'error'
self.status = errmsg self.status = self.errmsg
return True return True
elif self.ptype == 'unavailable':
for jid in [self.jid, self.fjid]:
if jid not in self.conn.sessions:
continue
# automatically terminate sessions that they haven't sent a thread
# ID in, only if other part support thread ID
for sess in self.conn.sessions[jid].values():
if not sess.received_thread_id:
contact = gajim.contacts.get_contact(self.conn.name,
jid)
# FIXME: I don't know if this is the correct behavior here.
# Anyway, it is the old behavior when we assumed that
# not-existing contacts don't support anything
contact_exists = bool(contact)
session_supported = contact_exists and (
contact.supports(xmpp.NS_SSN) or
contact.supports(xmpp.NS_ESESSION))
if session_supported:
sess.terminate()
del self.conn.sessions[jid][sess.thread_id]
if self.avatar_sha is not None and self.ptype != 'error':
if self.jid not in self.conn.vcard_shas:
cached_vcard = self.conn.get_cached_vcard(self.jid)
if cached_vcard and 'PHOTO' in cached_vcard and \
'SHA' in cached_vcard['PHOTO']:
self.conn.vcard_shas[self.jid] = \
cached_vcard['PHOTO']['SHA']
else:
self.conn.vcard_shas[self.jid] = ''
if self.avatar_sha != self.conn.vcard_shas[self.jid]:
# avatar has been updated
self.conn.request_vcard(self.jid)
if not self.ptype or self.ptype == 'unavailable': if not self.ptype or self.ptype == 'unavailable':
if gajim.config.get('log_contact_status_changes') and \
gajim.config.should_log(self.conn.name, self.jid):
try:
gajim.logger.write('status', self.jid, self.status,
self.show)
except exceptions.PysqliteOperationalError, e:
self.conn.dispatch('DB_ERROR', (_('Disk Write Error'), str(e)))
except exceptions.DatabaseMalformed:
pritext = _('Database Error')
sectext = _('The database file (%s) cannot be read. Try to '
'repair it (see '
'http://trac.gajim.org/wiki/DatabaseBackup) or remove '
'it (all history will be lost).') % LOG_DB_PATH
self.conn.dispatch('DB_ERROR', (pritext, sectext))
our_jid = gajim.get_jid_from_account(self.conn.name) our_jid = gajim.get_jid_from_account(self.conn.name)
if self.jid == our_jid and self.resource == \ if self.jid == our_jid and self.resource == \
self.conn.server_resource: self.conn.server_resource:
@ -808,9 +758,9 @@ class GcPresenceReceivedEvent(nec.NetworkIncomingEvent):
self.show = self.presence_obj.show self.show = self.presence_obj.show
self.status = self.presence_obj.status self.status = self.presence_obj.status
self.avatar_sha = self.presence_obj.avatar_sha self.avatar_sha = self.presence_obj.avatar_sha
self.errcode = self.presence_obj.errcode
self.errmsg = self.presence_obj.errmsg
self.errcon = self.iq_obj.getError() self.errcon = self.iq_obj.getError()
self.errmsg = self.iq_obj.getErrorMsg()
self.errcode = self.iq_obj.getErrorCode()
self.get_gc_control() self.get_gc_control()
self.gc_contact = gajim.contacts.get_gc_contact(self.conn.name, self.gc_contact = gajim.contacts.get_gc_contact(self.conn.name,
self.room_jid, self.nick) self.room_jid, self.nick)

View File

@ -165,7 +165,7 @@ class Interface:
'id': obj.iq_id}, sec_msg, on_response_yes=(on_yes, obj), 'id': obj.iq_id}, sec_msg, on_response_yes=(on_yes, obj),
on_response_no=(response, obj, 'no')) on_response_no=(response, obj, 'no'))
def handle_event_error_answer(self, obj): def handle_event_iq_error(self, obj):
#('ERROR_ANSWER', account, (id_, fjid, errmsg, errcode)) #('ERROR_ANSWER', account, (id_, fjid, errmsg, errcode))
if unicode(obj.errcode) in ('400', '403', '406') and obj.id_: if unicode(obj.errcode) in ('400', '403', '406') and obj.id_:
# show the error dialog # show the error dialog
@ -1959,7 +1959,7 @@ class Interface:
'ARCHIVING_CHANGED': [self.handle_event_archiving_changed], 'ARCHIVING_CHANGED': [self.handle_event_archiving_changed],
'ARCHIVING_ERROR': [self.handle_event_archiving_error], 'ARCHIVING_ERROR': [self.handle_event_archiving_error],
'bookmarks-received': [self.handle_event_bookmarks], 'bookmarks-received': [self.handle_event_bookmarks],
'error-received': [self.handle_event_error_answer], 'iq-error-received': [self.handle_event_iq_error],
'gc-presence-received': [self.handle_event_gc_presence], 'gc-presence-received': [self.handle_event_gc_presence],
'gmail-notify': [self.handle_event_gmail_notify], 'gmail-notify': [self.handle_event_gmail_notify],
'http-auth-received': [self.handle_event_http_auth], 'http-auth-received': [self.handle_event_http_auth],