use NEC to handle fingerprint error events
This commit is contained in:
parent
b80254e20e
commit
4fb9b442c8
|
@ -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',
|
||||||
|
|
|
@ -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 = []
|
||||||
|
|
|
@ -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],
|
||||||
|
|
Loading…
Reference in New Issue