[gjc] handle the case when gnomekeyring is present, but daemon is not running
This commit is contained in:
parent
6d1097f1e2
commit
e0e503472a
|
@ -25,8 +25,14 @@ except ImportError:
|
||||||
else:
|
else:
|
||||||
USER_HAS_GNOMEKEYRING = True
|
USER_HAS_GNOMEKEYRING = True
|
||||||
|
|
||||||
|
class PasswordStorage(object):
|
||||||
|
def get_password(self, account_name):
|
||||||
|
raise NotImplementedError
|
||||||
|
def save_password(self, account_name, password):
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
class SimplePasswordStorage(object):
|
|
||||||
|
class SimplePasswordStorage(PasswordStorage):
|
||||||
def get_password(self, account_name):
|
def get_password(self, account_name):
|
||||||
return gajim.config.get_per('accounts', account_name, 'password')
|
return gajim.config.get_per('accounts', account_name, 'password')
|
||||||
|
|
||||||
|
@ -35,7 +41,7 @@ class SimplePasswordStorage(object):
|
||||||
gajim.connections[account_name].password = password
|
gajim.connections[account_name].password = password
|
||||||
|
|
||||||
|
|
||||||
class GnomePasswordStorage(object):
|
class GnomePasswordStorage(PasswordStorage):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.keyring = gnomekeyring.get_default_keyring_sync()
|
self.keyring = gnomekeyring.get_default_keyring_sync()
|
||||||
|
|
||||||
|
@ -49,13 +55,21 @@ class GnomePasswordStorage(object):
|
||||||
except ValueError:
|
except ValueError:
|
||||||
password = conf
|
password = conf
|
||||||
## migrate the password over to keyring
|
## migrate the password over to keyring
|
||||||
|
try:
|
||||||
self.save_password(account_name, password, update=False)
|
self.save_password(account_name, password, update=False)
|
||||||
|
except gnomekeyring.NoKeyringDaemonError:
|
||||||
|
## no keyring daemon: in the future, stop using it
|
||||||
|
set_storage(SimplePasswordStorage())
|
||||||
return password
|
return password
|
||||||
try:
|
try:
|
||||||
return gnomekeyring.item_get_info_sync(self.keyring,
|
return gnomekeyring.item_get_info_sync(self.keyring,
|
||||||
auth_token).get_secret()
|
auth_token).get_secret()
|
||||||
except gnomekeyring.DeniedError:
|
except gnomekeyring.DeniedError:
|
||||||
return None
|
return None
|
||||||
|
except gnomekeyring.NoKeyringDaemonError:
|
||||||
|
## no keyring daemon: in the future, stop using it
|
||||||
|
set_storage(SimplePasswordStorage())
|
||||||
|
return None
|
||||||
|
|
||||||
def save_password(self, account_name, password, update=True):
|
def save_password(self, account_name, password, update=True):
|
||||||
display_name = _('Gajim account %s') % account_name
|
display_name = _('Gajim account %s') % account_name
|
||||||
|
@ -72,11 +86,20 @@ def get_storage():
|
||||||
global storage
|
global storage
|
||||||
if storage is None: # None is only in first time get_storage is called
|
if storage is None: # None is only in first time get_storage is called
|
||||||
if USER_HAS_GNOMEKEYRING:
|
if USER_HAS_GNOMEKEYRING:
|
||||||
|
try:
|
||||||
storage = GnomePasswordStorage()
|
storage = GnomePasswordStorage()
|
||||||
|
except gnomekeyring.NoKeyringDaemonError:
|
||||||
|
storage = SimplePasswordStorage()
|
||||||
else:
|
else:
|
||||||
storage = SimplePasswordStorage()
|
storage = SimplePasswordStorage()
|
||||||
return storage
|
return storage
|
||||||
|
|
||||||
|
def set_storage(storage_):
|
||||||
|
global storage
|
||||||
|
assert isinstance(storage, PasswordStorage)
|
||||||
|
storage = storage_
|
||||||
|
|
||||||
|
|
||||||
def get_password(account_name):
|
def get_password(account_name):
|
||||||
return get_storage().get_password(account_name)
|
return get_storage().get_password(account_name)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue