summaryrefslogtreecommitdiff
path: root/openstackclient/common/openstackkeyring.py
diff options
context:
space:
mode:
authorBhuvan Arumugam <bhuvan@apache.org>2012-07-08 16:06:32 -0700
committerBhuvan Arumugam <bhuvan@apache.org>2012-08-15 12:13:36 -0700
commitf0cefcc77d593198b6e295e92a8bf05fedc8c8ff (patch)
tree900e5d877aff188e920ce083ea4608b6f9523e40 /openstackclient/common/openstackkeyring.py
parent540c4883d6f2de25dd38db0c18d59d568cd35f1e (diff)
downloadpython-openstackclient-f0cefcc77d593198b6e295e92a8bf05fedc8c8ff.tar.gz
Keyring support for openstackclient.
Bug: 1030440 If password is defined in keyring, use it; otherwise, prompt for the password. Keying is configured using command line switch, --os-use-keyring or env(OS_USE_KEYRING). * openstackclient/common/openstackkeyring.py The abstract class for keyring, specifically for openstack. The class is used to store encrypted password in keyring, without prompting for keyring password. The encrypted password is stored in ~/.openstack-keyring.cfg file. * openstack-common.py Update openstackkeyring library from openstack.common. * openstackclient/shell.py OpenStackClient.build_option_parser(): New boolean argument, --os-use-keyring, default to env(OS_USE_KEYRING). OpenStackClient.authenticate_user(): Get password from keyring, if it is defined; otherwise, prompt for the password. If user enter a password and keyring is enabled, store it in keyring. OpenStackClient.init_keyring_backend(): New method to define openstack backend for keyring. OpenStackClient.get_password_from_keyring(): New method to get password from keyring. OpenStackClient.set_password_in_keyring(): New method go set password in keyring. * toos/pip-requires Define keyring and pycrypto as one of dependent. Change-Id: I36d3a63054658c0ef0553d68b38fefbc236930ef
Diffstat (limited to 'openstackclient/common/openstackkeyring.py')
-rw-r--r--openstackclient/common/openstackkeyring.py65
1 files changed, 65 insertions, 0 deletions
diff --git a/openstackclient/common/openstackkeyring.py b/openstackclient/common/openstackkeyring.py
new file mode 100644
index 00000000..3a5ce27f
--- /dev/null
+++ b/openstackclient/common/openstackkeyring.py
@@ -0,0 +1,65 @@
+# Copyright 2011 OpenStack LLC.
+# All Rights Reserved
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+"""
+Keyring backend for Openstack, to store encrypted password in a file.
+"""
+
+from Crypto.Cipher import AES
+
+import crypt
+import keyring
+import os
+
+KEYRING_FILE = os.path.join(os.path.expanduser('~'), '.openstack-keyring.cfg')
+
+
+class OpenstackKeyring(keyring.backend.BasicFileKeyring):
+ """ Openstack Keyring to store encrypted password """
+
+ filename = KEYRING_FILE
+
+ def supported(self):
+ """ applicable for all platforms, but not recommend """
+ pass
+
+ def _init_crypter(self):
+ """ initialize the crypter using the class name """
+ block_size = 32
+ padding = '0'
+
+ # init the cipher with the class name, upto block_size
+ password = __name__[block_size:]
+ password = password + (block_size - len(password) % \
+ block_size) * padding
+ return AES.new(password, AES.MODE_CFB)
+
+ def encrypt(self, password):
+ """ encrypt the given password """
+ crypter = self._init_crypter()
+ return crypter.encrypt(password)
+
+ def decrypt(self, password_encrypted):
+ """ decrypt the given password """
+ crypter = self._init_crypter()
+ return crypter.decrypt(password_encrypted)
+
+
+def os_keyring():
+ """ initialize the openstack keyring """
+ return keyring.core.load_keyring(None,
+ 'openstackclient.common.openstackkeyring.OpenstackKeyring')