]> granicus.if.org Git - python/commitdiff
bug #1177468: don't cache /dev/urandom file descriptor in os.urandom
authorGeorg Brandl <georg@python.org>
Mon, 4 Jul 2005 17:16:07 +0000 (17:16 +0000)
committerGeorg Brandl <georg@python.org>
Mon, 4 Jul 2005 17:16:07 +0000 (17:16 +0000)
Lib/os.py
Misc/NEWS

index 5824609b14daaa441264651ec5f0165e8b913f0d..bf1b086383338ff740bf7405bb9b25ab004ce1a5 100644 (file)
--- a/Lib/os.py
+++ b/Lib/os.py
@@ -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
index 8d86efde286cbbec1ab77ce6101be3bdb94f842b..bcc696ae975212ec7b6a6d447809a5c7060b2c94 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -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