use NEC to handle fingerprint error events

This commit is contained in:
Yann Leboulanger 2010-11-24 17:00:14 +01:00
parent b80254e20e
commit 4fb9b442c8
3 changed files with 16 additions and 8 deletions

View File

@ -1260,8 +1260,9 @@ class Connection(CommonConnection, ConnectionHandlers):
if saved_fingerprint: if saved_fingerprint:
# Check sha1 fingerprint # Check sha1 fingerprint
if con.Connection.ssl_fingerprint_sha1 != saved_fingerprint: if con.Connection.ssl_fingerprint_sha1 != saved_fingerprint:
self.dispatch('FINGERPRINT_ERROR', gajim.nec.push_incoming_event(FingerprintErrorEvent(None,
(con.Connection.ssl_fingerprint_sha1,)) conn=self,
new_fingerprint=con.Connection.ssl_fingerprint_sha1))
return True return True
else: else:
gajim.config.set_per('accounts', self.name, 'ssl_fingerprint_sha1', gajim.config.set_per('accounts', self.name, 'ssl_fingerprint_sha1',

View File

@ -1447,3 +1447,7 @@ class InsecureSSLConnectionEvent(nec.NetworkIncomingEvent):
class SSLErrorEvent(nec.NetworkIncomingEvent): class SSLErrorEvent(nec.NetworkIncomingEvent):
name = 'ssl-error' name = 'ssl-error'
base_network_events = [] base_network_events = []
class FingerprintErrorEvent(nec.NetworkIncomingEvent):
name = 'fingerprint-error'
base_network_events = []

View File

@ -1468,26 +1468,29 @@ class Interface:
dialogs.ConfirmationDialogDoubleCheck(pritext, sectext, checktext1, dialogs.ConfirmationDialogDoubleCheck(pritext, sectext, checktext1,
checktext2, on_response_ok=on_ok, on_response_cancel=on_cancel) checktext2, on_response_ok=on_ok, on_response_cancel=on_cancel)
def handle_event_fingerprint_error(self, account, data): def handle_event_fingerprint_error(self, obj):
# ('FINGERPRINT_ERROR', account, (new_fingerprint,)) # ('FINGERPRINT_ERROR', account, (new_fingerprint,))
account = obj.conn.name
def on_yes(is_checked): def on_yes(is_checked):
del self.instances[account]['online_dialog']['fingerprint_error'] del self.instances[account]['online_dialog']['fingerprint_error']
gajim.config.set_per('accounts', account, 'ssl_fingerprint_sha1', gajim.config.set_per('accounts', account, 'ssl_fingerprint_sha1',
data[0]) obj.new_fingerprint)
# Reset the ignored ssl errors # Reset the ignored ssl errors
gajim.config.set_per('accounts', account, 'ignore_ssl_errors', '') gajim.config.set_per('accounts', account, 'ignore_ssl_errors', '')
gajim.connections[account].ssl_certificate_accepted() obj.conn.ssl_certificate_accepted()
def on_no(): def on_no():
del self.instances[account]['online_dialog']['fingerprint_error'] del self.instances[account]['online_dialog']['fingerprint_error']
gajim.connections[account].disconnect(on_purpose=True) obj.conn.disconnect(on_purpose=True)
self.handle_event_status(account, 'offline') self.handle_event_status(account, 'offline')
pritext = _('SSL certificate error') pritext = _('SSL certificate error')
sectext = _('It seems the SSL certificate of account %(account)s has ' sectext = _('It seems the SSL certificate of account %(account)s has '
'changed or your connection is being hacked.\nOld fingerprint: ' 'changed or your connection is being hacked.\nOld fingerprint: '
'%(old)s\nNew fingerprint: %(new)s\n\nDo you still want to connect ' '%(old)s\nNew fingerprint: %(new)s\n\nDo you still want to connect '
'and update the fingerprint of the certificate?') % \ 'and update the fingerprint of the certificate?') % \
{'account': account, 'old': gajim.config.get_per('accounts', {'account': account, 'old': gajim.config.get_per('accounts',
account, 'ssl_fingerprint_sha1'), 'new': data[0]} account, 'ssl_fingerprint_sha1'), 'new': obj.new_fingerprint}
if 'fingerprint_error' in self.instances[account]['online_dialog']: if 'fingerprint_error' in self.instances[account]['online_dialog']:
self.instances[account]['online_dialog']['fingerprint_error'].\ self.instances[account]['online_dialog']['fingerprint_error'].\
destroy() destroy()
@ -1642,11 +1645,11 @@ class Interface:
'UNIQUE_ROOM_ID_SUPPORTED': \ 'UNIQUE_ROOM_ID_SUPPORTED': \
[self.handle_event_unique_room_id_supported], [self.handle_event_unique_room_id_supported],
'PASSWORD_REQUIRED': [self.handle_event_password_required], 'PASSWORD_REQUIRED': [self.handle_event_password_required],
'FINGERPRINT_ERROR': [self.handle_event_fingerprint_error],
'atom-entry-received': [self.handle_atom_entry], 'atom-entry-received': [self.handle_atom_entry],
'bad-gpg-passphrase': [self.handle_event_bad_gpg_passphrase], 'bad-gpg-passphrase': [self.handle_event_bad_gpg_passphrase],
'bookmarks-received': [self.handle_event_bookmarks], 'bookmarks-received': [self.handle_event_bookmarks],
'connection-lost': [self.handle_event_connection_lost], 'connection-lost': [self.handle_event_connection_lost],
'fingerprint-error': [self.handle_event_fingerprint_error],
'gc-invitation-received': [self.handle_event_gc_invitation], 'gc-invitation-received': [self.handle_event_gc_invitation],
'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],