diff options
author | Rick Harris <rick.harris@rackspace.com> | 2011-02-18 17:33:18 +0000 |
---|---|---|
committer | Rick Harris <rick.harris@rackspace.com> | 2011-02-18 17:33:18 +0000 |
commit | 36ccb108da5b4e205e26649425b63b40fe069ee2 (patch) | |
tree | ca54a1c25db48e7ff37a58357bb1e73d61b12d86 /nova/utils.py | |
parent | 8dceaccb81e95b55fac2156df4f04ef0a7469112 (diff) | |
parent | 5dfa5ce7d1374509fea51f8d0b132ea865f34dc6 (diff) | |
download | nova-36ccb108da5b4e205e26649425b63b40fe069ee2.tar.gz nova-36ccb108da5b4e205e26649425b63b40fe069ee2.tar.xz nova-36ccb108da5b4e205e26649425b63b40fe069ee2.zip |
Merging trunk
Diffstat (limited to 'nova/utils.py')
-rw-r--r-- | nova/utils.py | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/nova/utils.py b/nova/utils.py index ba71ebf39..42efa0008 100644 --- a/nova/utils.py +++ b/nova/utils.py @@ -20,12 +20,14 @@ System-level utilities and helper functions. """ +import base64 import datetime import inspect import json import os import random import socket +import string import struct import sys import time @@ -235,6 +237,15 @@ def generate_mac(): return ':'.join(map(lambda x: "%02x" % x, mac)) +def generate_password(length=20): + """Generate a random sequence of letters and digits + to be used as a password. Note that this is not intended + to represent the ultimate in security. + """ + chrs = string.letters + string.digits + return "".join([random.choice(chrs) for i in xrange(length)]) + + def last_octet(address): return int(address.split(".")[-1]) @@ -476,3 +487,15 @@ def dumps(value): def loads(s): return json.loads(s) + + +def ensure_b64_encoding(val): + """Safety method to ensure that values expected to be base64-encoded + actually are. If they are, the value is returned unchanged. Otherwise, + the encoded value is returned. + """ + try: + dummy = base64.decode(val) + return val + except TypeError: + return base64.b64encode(val) |