Store passwords in Windows Credential Vault

This commit is contained in:
Philipp Hörist 2016-12-11 01:20:16 +01:00
parent 6a369702f8
commit 9d13631731
1 changed files with 43 additions and 5 deletions

View File

@ -24,11 +24,21 @@
## along with Gajim. If not, see <http://www.gnu.org/licenses/>. ## along with Gajim. If not, see <http://www.gnu.org/licenses/>.
## ##
import os
import logging
import gi
from common import gajim
__all__ = ['get_password', 'save_password'] __all__ = ['get_password', 'save_password']
import warnings log = logging.getLogger('gajim.password')
from common import gajim
import gi if os.name == 'nt':
try:
import keyring
except ImportError:
log.debug('python-keyring missing, falling back to plaintext storage')
Secret = None Secret = None
@ -99,6 +109,32 @@ class SecretPasswordStorage(PasswordStorage):
gajim.connections[account_name].password = password gajim.connections[account_name].password = password
class SecretWindowsPasswordStorage(PasswordStorage):
""" Windows Keyring """
def __init__(self):
self.win_keyring = keyring.get_keyring()
def save_password(self, account_name, password):
self.win_keyring.set_password('gajim', account_name, password)
gajim.config.set_per('accounts', account_name, 'password', 'winvault:')
def get_password(self, account_name):
log.debug('getting password')
conf = gajim.config.get_per('accounts', account_name, 'password')
if conf is None:
return None
if not conf.startswith('winvault:'):
password = conf
# migrate the password over to keyring
try:
self.save_password(account_name, password)
except Exception:
log.exception('error: ')
return password
return self.win_keyring.get_password('gajim', account_name)
storage = None storage = None
def get_storage(): def get_storage():
global storage global storage
@ -112,7 +148,10 @@ def get_storage():
except (ValueError, AttributeError): except (ValueError, AttributeError):
pass pass
try: try:
storage = SecretPasswordStorage() if os.name != 'nt':
storage = SecretPasswordStorage()
else:
storage = SecretWindowsPasswordStorage()
except Exception: except Exception:
storage = SimplePasswordStorage() storage = SimplePasswordStorage()
return storage return storage
@ -121,7 +160,6 @@ def set_storage(storage_):
global storage global storage
storage = storage_ 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)