Commit 1deb8c2b authored by Georg Brandl's avatar Georg Brandl

Issue #19855: uuid.getnode() on Unix now looks on the PATH for the

executables used to find the mac address, with /sbin and /usr/sbin as
fallbacks.

Issue #11508: Fixed uuid.getnode() and uuid.uuid1() on environment with
virtual interface.  Original patch by Kent Frazier.

Issue #18784: The uuid module no more attempts to load libc via ctypes.CDLL,
if all necessary functions are already found in libuuid.
Patch by Evgeny Sologubov.

Issue #16102: Make uuid._netbios_getnode() work again on Python 3.
parent f1806ea5
from unittest import TestCase from unittest import TestCase
from test import support from test import support
import builtins import builtins
import io
import os
import uuid import uuid
def importable(name): def importable(name):
...@@ -360,6 +362,25 @@ class TestUUID(TestCase): ...@@ -360,6 +362,25 @@ class TestUUID(TestCase):
self.assertEqual(node1, node2) self.assertEqual(node1, node2)
def test_find_mac(self):
data = '''\
fake hwaddr
cscotun0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
eth0 Link encap:Ethernet HWaddr 12:34:56:78:90:ab
'''
def mock_popen(cmd):
return io.StringIO(data)
with support.swap_attr(os, 'popen', mock_popen):
mac = uuid._find_mac(
command='ifconfig',
args='',
hw_identifiers=['hwaddr'],
get_index=lambda x: x + 1,
)
self.assertEqual(mac, 0x1234567890ab)
def test_uuid1(self): def test_uuid1(self):
# uuid1 requires ctypes. # uuid1 requires ctypes.
try: try:
......
...@@ -313,13 +313,19 @@ class UUID(object): ...@@ -313,13 +313,19 @@ class UUID(object):
def _find_mac(command, args, hw_identifiers, get_index): def _find_mac(command, args, hw_identifiers, get_index):
import os import os
for dir in ['', '/sbin/', '/usr/sbin']: path = os.environ.get("PATH", os.defpath).split(os.pathsep)
path.extend(('/sbin', '/usr/sbin'))
for dir in path:
executable = os.path.join(dir, command) executable = os.path.join(dir, command)
if not os.path.exists(executable): if (os.path.exists(executable) and
continue os.access(executable, os.F_OK | os.X_OK) and
not os.path.isdir(executable)):
break
else:
return None
try: try:
# LC_ALL to get English output, 2>/dev/null to # LC_ALL to ensure English output, 2>/dev/null to
# prevent output on stderr # prevent output on stderr
cmd = 'LC_ALL=C %s %s 2>/dev/null' % (executable, args) cmd = 'LC_ALL=C %s %s 2>/dev/null' % (executable, args)
with os.popen(cmd) as pipe: with os.popen(cmd) as pipe:
...@@ -327,11 +333,18 @@ def _find_mac(command, args, hw_identifiers, get_index): ...@@ -327,11 +333,18 @@ def _find_mac(command, args, hw_identifiers, get_index):
words = line.lower().split() words = line.lower().split()
for i in range(len(words)): for i in range(len(words)):
if words[i] in hw_identifiers: if words[i] in hw_identifiers:
try:
return int( return int(
words[get_index(i)].replace(':', ''), 16) words[get_index(i)].replace(':', ''), 16)
except (ValueError, IndexError):
# Virtual interfaces, such as those provided by
# VPNs, do not have a colon-delimited MAC address
# as expected, but a 16-byte HWAddr separated by
# dashes. These should be ignored in favor of a
# real MAC address
pass
except IOError: except IOError:
continue pass
return None
def _ifconfig_getnode(): def _ifconfig_getnode():
"""Get the hardware address on Unix by running ifconfig.""" """Get the hardware address on Unix by running ifconfig."""
...@@ -406,7 +419,7 @@ def _netbios_getnode(): ...@@ -406,7 +419,7 @@ def _netbios_getnode():
if win32wnet.Netbios(ncb) != 0: if win32wnet.Netbios(ncb) != 0:
continue continue
status._unpack() status._unpack()
bytes = map(ord, status.adapter_address) bytes = status.adapter_address
return ((bytes[0]<<40) + (bytes[1]<<32) + (bytes[2]<<24) + return ((bytes[0]<<40) + (bytes[1]<<32) + (bytes[2]<<24) +
(bytes[3]<<16) + (bytes[4]<<8) + bytes[5]) (bytes[3]<<16) + (bytes[4]<<8) + bytes[5])
...@@ -429,6 +442,8 @@ try: ...@@ -429,6 +442,8 @@ try:
_uuid_generate_random = lib.uuid_generate_random _uuid_generate_random = lib.uuid_generate_random
if hasattr(lib, 'uuid_generate_time'): if hasattr(lib, 'uuid_generate_time'):
_uuid_generate_time = lib.uuid_generate_time _uuid_generate_time = lib.uuid_generate_time
if _uuid_generate_random is not None:
break # found everything we were looking for
# The uuid_generate_* functions are broken on MacOS X 10.5, as noted # The uuid_generate_* functions are broken on MacOS X 10.5, as noted
# in issue #8621 the function generates the same sequence of values # in issue #8621 the function generates the same sequence of values
......
...@@ -353,6 +353,7 @@ Doug Fort ...@@ -353,6 +353,7 @@ Doug Fort
John Fouhy John Fouhy
Stefan Franke Stefan Franke
Martin Franklin Martin Franklin
Kent Frazier
Robin Friedrich Robin Friedrich
Bradley Froehle Bradley Froehle
Ivan Frohne Ivan Frohne
...@@ -1028,6 +1029,7 @@ Ryan Smith-Roberts ...@@ -1028,6 +1029,7 @@ Ryan Smith-Roberts
Rafal Smotrzyk Rafal Smotrzyk
Dirk Soede Dirk Soede
Paul Sokolovsky Paul Sokolovsky
Evgeny Sologubov
Cody Somerville Cody Somerville
Clay Spence Clay Spence
Stefan Sperling Stefan Sperling
......
...@@ -47,6 +47,19 @@ Library ...@@ -47,6 +47,19 @@ Library
with non-standard cookie handling in some Web browsers. Reported by with non-standard cookie handling in some Web browsers. Reported by
Sergey Bobrov. Sergey Bobrov.
- Issue #19855: uuid.getnode() on Unix now looks on the PATH for the
executables used to find the mac address, with /sbin and /usr/sbin as
fallbacks.
- Issue #11508: Fixed uuid.getnode() and uuid.uuid1() on environment with
virtual interface. Original patch by Kent Frazier.
- Issue #18784: The uuid module no more attempts to load libc via ctypes.CDLL,
if all necessary functions are already found in libuuid.
Patch by Evgeny Sologubov.
- Issue #16102: Make uuid._netbios_getnode() work again on Python 3.
- Issue #21766: Prevent a security hole in CGIHTTPServer by URL unquoting paths - Issue #21766: Prevent a security hole in CGIHTTPServer by URL unquoting paths
before checking for a CGI script at that path. before checking for a CGI script at that path.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment