/usr/lib/python2.7/dist-packages/ubuntu-sso-client/ubuntu_sso/keyring/pykeyring.py is in python-ubuntu-sso-client 13.10-0ubuntu11.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 | # -*- coding: utf-8 -*-
#
# Copyright 2011-2012 Canonical Ltd.
#
# This program is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License version 3, as published
# by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranties of
# MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR
# PURPOSE. See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program. If not, see <http://www.gnu.org/licenses/>.
#
# In addition, as a special exception, the copyright holders give
# permission to link the code of portions of this program with the
# OpenSSL library under certain conditions as described in each
# individual source file, and distribute linked combinations
# including the two.
# You must obey the GNU General Public License in all respects
# for all of the code used other than OpenSSL. If you modify
# file(s) with this exception, you may extend this exception to your
# version of the file(s), but you are not obligated to do so. If you
# do not wish to do so, delete this exception statement from your
# version. If you delete this exception statement from all source
# files in the program, then also delete it here.
"""Keyring implementation for Windows and Darwin."""
from json import loads, dumps
from ubuntu_sso.utils.qtwisted import qtDeferToThread as deferToThread
USERNAME = 'ubuntu_sso'
class Keyring(object):
"""A Keyring for a given application name."""
def __init__(self, keyring=None):
"""Create a new instance."""
if keyring is None:
import keyring as pykeyring
keyring = pykeyring
self.keyring = keyring
def set_credentials(self, app_name, cred):
"""Set the credentials of the Ubuntu SSO item."""
# the windows keyring can only store a pair username-password
# so we store the data using ubuntu_sso as the user name. Then
# the cred will be stored as the string representation of the dict.
return deferToThread(self.keyring.set_password, app_name, USERNAME,
dumps(cred))
def _get_credentials_obj(self, app_name):
"""A dict with the credentials."""
creds = self.keyring.get_password(app_name, USERNAME)
if creds:
return loads(creds)
def get_credentials(self, app_name):
"""A deferred with the secret of the SSO item in a dictionary."""
return deferToThread(self._get_credentials_obj, app_name)
def delete_credentials(self, app_name):
"""Delete a set of credentials from the keyring."""
# this call depends on a patch I sent to pykeyring. The patch has
# not landed as of version 0.5.1. If you have that version you can
# clone my patch in the following way:
# hg clone https://bitbucket.org/mandel/pykeyring-delete-password
# pylint: disable=E1103
return deferToThread(self.keyring.delete_password, app_name, USERNAME)
|