diff options
author | Georg Brandl <georg@python.org> | 2005-07-04 17:16:07 (GMT) |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2005-07-04 17:16:07 (GMT) |
commit | 9e43acf2f31e67a976475c2c9f8674dd27571cc6 (patch) | |
tree | bfb6a9b8964ed76eb818738357c68c11471717ba | |
parent | 290f3829d79f5ed4073ea0bef8345fcd72ad9ec9 (diff) | |
download | cpython-9e43acf2f31e67a976475c2c9f8674dd27571cc6.zip cpython-9e43acf2f31e67a976475c2c9f8674dd27571cc6.tar.gz cpython-9e43acf2f31e67a976475c2c9f8674dd27571cc6.tar.bz2 |
bug #1177468: don't cache /dev/urandom file descriptor in os.urandom
-rw-r--r-- | Lib/os.py | 12 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
2 files changed, 7 insertions, 8 deletions
@@ -715,22 +715,18 @@ except NameError: # statvfs_result may not exist pass if not _exists("urandom"): - _urandomfd = None def urandom(n): """urandom(n) -> str Return a string of n random bytes suitable for cryptographic use. """ - global _urandomfd - if _urandomfd is None: - try: - _urandomfd = open("/dev/urandom", O_RDONLY) - except: - _urandomfd = NotImplementedError - if _urandomfd is NotImplementedError: + try: + _urandomfd = open("/dev/urandom", O_RDONLY) + except: raise NotImplementedError("/dev/urandom (or equivalent) not found") bytes = "" while len(bytes) < n: bytes += read(_urandomfd, n - len(bytes)) + close(_urandomfd) return bytes @@ -150,6 +150,9 @@ Extension Modules Library ------- +- Bug #1177468: Don't cache the /dev/urandom file descriptor for os.urandom, + as this can cause problems with apps closing all file descriptors. + - Bug #839151: Fix an attempt to access sys.argv in the warnings module though this can be missing in embedded interpreters |