- 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:
parent
e2c270a67c
commit
4d14935987
|
@ -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:
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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],
|
||||||
|
|
Loading…
Reference in New Issue