|
|
@ -351,13 +351,26 @@ class Facts(object):
|
|
|
|
data = get_file_content(path)
|
|
|
|
data = get_file_content(path)
|
|
|
|
if 'suse' in data.lower():
|
|
|
|
if 'suse' in data.lower():
|
|
|
|
if path == '/etc/os-release':
|
|
|
|
if path == '/etc/os-release':
|
|
|
|
release = re.search("PRETTY_NAME=[^(]+ \(?([^)]+?)\)", data)
|
|
|
|
for line in data.splitlines():
|
|
|
|
distdata = get_file_content(path).split('\n')[0]
|
|
|
|
distribution = re.search("^NAME=(.*)", line)
|
|
|
|
self.facts['distribution'] = distdata.split('=')[1]
|
|
|
|
if distribution:
|
|
|
|
|
|
|
|
self.facts['distribution'] = distribution.group(1).strip('"')
|
|
|
|
|
|
|
|
distribution_version = re.search('^VERSION_ID="?([0-9]+\.?[0-9]*)"?', line) # example pattern are 13.04 13.0 13
|
|
|
|
|
|
|
|
if distribution_version:
|
|
|
|
|
|
|
|
self.facts['distribution_version'] = distribution_version.group(1)
|
|
|
|
|
|
|
|
if 'open' in data.lower():
|
|
|
|
|
|
|
|
release = re.search("^PRETTY_NAME=[^(]+ \(?([^)]+?)\)", line)
|
|
|
|
if release:
|
|
|
|
if release:
|
|
|
|
self.facts['distribution_release'] = release.groups()[0]
|
|
|
|
self.facts['distribution_release'] = release.groups()[0]
|
|
|
|
break
|
|
|
|
elif 'enterprise' in data.lower():
|
|
|
|
|
|
|
|
release = re.search('^VERSION_ID="?[0-9]+\.?([0-9]*)"?', line) # SLES doesn't got funny release names
|
|
|
|
|
|
|
|
if release:
|
|
|
|
|
|
|
|
release = release.group(1)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
release = "0" # no minor number, so it is the first release
|
|
|
|
|
|
|
|
self.facts['distribution_release'] = release
|
|
|
|
elif path == '/etc/SuSE-release':
|
|
|
|
elif path == '/etc/SuSE-release':
|
|
|
|
|
|
|
|
if 'open' in data.lower():
|
|
|
|
data = data.splitlines()
|
|
|
|
data = data.splitlines()
|
|
|
|
distdata = get_file_content(path).split('\n')[0]
|
|
|
|
distdata = get_file_content(path).split('\n')[0]
|
|
|
|
self.facts['distribution'] = distdata.split()[0]
|
|
|
|
self.facts['distribution'] = distdata.split()[0]
|
|
|
@ -366,6 +379,19 @@ class Facts(object):
|
|
|
|
if release:
|
|
|
|
if release:
|
|
|
|
self.facts['distribution_release'] = release.groups()[0].strip()
|
|
|
|
self.facts['distribution_release'] = release.groups()[0].strip()
|
|
|
|
break
|
|
|
|
break
|
|
|
|
|
|
|
|
elif 'enterprise' in data.lower():
|
|
|
|
|
|
|
|
lines = data.splitlines()
|
|
|
|
|
|
|
|
distribution = lines[0].split()[0]
|
|
|
|
|
|
|
|
if "Server" in data:
|
|
|
|
|
|
|
|
self.facts['distribution'] = "SLES"
|
|
|
|
|
|
|
|
elif "Desktop" in data:
|
|
|
|
|
|
|
|
self.facts['distribution'] = "SLED"
|
|
|
|
|
|
|
|
for line in lines:
|
|
|
|
|
|
|
|
release = re.search('PATCHLEVEL = ([0-9]+)', line) # SLES doesn't got funny release names
|
|
|
|
|
|
|
|
if release:
|
|
|
|
|
|
|
|
self.facts['distribution_release'] = release.group(1)
|
|
|
|
|
|
|
|
self.facts['distribution_version'] = self.facts['distribution_version'] + '.' + release.group(1)
|
|
|
|
|
|
|
|
break
|
|
|
|
elif name == 'Debian':
|
|
|
|
elif name == 'Debian':
|
|
|
|
data = get_file_content(path)
|
|
|
|
data = get_file_content(path)
|
|
|
|
if 'Debian' in data:
|
|
|
|
if 'Debian' in data:
|
|
|
|