|
|
@ -130,7 +130,7 @@ class Facts(object):
|
|
|
|
self.facts['selinux']['policyvers'] = 'unknown'
|
|
|
|
self.facts['selinux']['policyvers'] = 'unknown'
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
(rc, configmode) = selinux.selinux_getenforcemode()
|
|
|
|
(rc, configmode) = selinux.selinux_getenforcemode()
|
|
|
|
if rc == 0 and Facts.SELINUX_MODE_DICT.has_key(configmode):
|
|
|
|
if rc == 0 and configmode in Facts.SELINUX_MODE_DICT:
|
|
|
|
self.facts['selinux']['config_mode'] = Facts.SELINUX_MODE_DICT[configmode]
|
|
|
|
self.facts['selinux']['config_mode'] = Facts.SELINUX_MODE_DICT[configmode]
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
self.facts['selinux']['config_mode'] = 'unknown'
|
|
|
|
self.facts['selinux']['config_mode'] = 'unknown'
|
|
|
@ -138,7 +138,7 @@ class Facts(object):
|
|
|
|
self.facts['selinux']['config_mode'] = 'unknown'
|
|
|
|
self.facts['selinux']['config_mode'] = 'unknown'
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
mode = selinux.security_getenforce()
|
|
|
|
mode = selinux.security_getenforce()
|
|
|
|
if Facts.SELINUX_MODE_DICT.has_key(mode):
|
|
|
|
if mode in Facts.SELINUX_MODE_DICT:
|
|
|
|
self.facts['selinux']['mode'] = Facts.SELINUX_MODE_DICT[mode]
|
|
|
|
self.facts['selinux']['mode'] = Facts.SELINUX_MODE_DICT[mode]
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
self.facts['selinux']['mode'] = 'unknown'
|
|
|
|
self.facts['selinux']['mode'] = 'unknown'
|
|
|
@ -196,19 +196,21 @@ class LinuxHardware(Hardware):
|
|
|
|
|
|
|
|
|
|
|
|
In addition, it also defines number of DMI facts.
|
|
|
|
In addition, it also defines number of DMI facts.
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
platform = 'Linux'
|
|
|
|
platform = 'Linux'
|
|
|
|
MEMORY_FACTS = ['MemTotal', 'SwapTotal', 'MemFree', 'SwapFree']
|
|
|
|
MEMORY_FACTS = ['MemTotal', 'SwapTotal', 'MemFree', 'SwapFree']
|
|
|
|
# DMI bits
|
|
|
|
# DMI bits
|
|
|
|
DMI_DICT = { 'form_factor': '/sys/devices/virtual/dmi/id/chassis_type',
|
|
|
|
DMI_DICT = dict(
|
|
|
|
'product_name': '/sys/devices/virtual/dmi/id/product_name',
|
|
|
|
form_factor = '/sys/devices/virtual/dmi/id/chassis_type',
|
|
|
|
'product_serial': '/sys/devices/virtual/dmi/id/product_serial',
|
|
|
|
product_name = '/sys/devices/virtual/dmi/id/product_name',
|
|
|
|
'product_uuid': '/sys/devices/virtual/dmi/id/product_uuid',
|
|
|
|
product_serial = '/sys/devices/virtual/dmi/id/product_serial',
|
|
|
|
'product_version': '/sys/devices/virtual/dmi/id/product_version',
|
|
|
|
product_uuid = '/sys/devices/virtual/dmi/id/product_uuid',
|
|
|
|
'system_vendor': '/sys/devices/virtual/dmi/id/sys_vendor',
|
|
|
|
product_version = '/sys/devices/virtual/dmi/id/product_version',
|
|
|
|
'bios_date': '/sys/devices/virtual/dmi/id/bios_date',
|
|
|
|
system_vendor = '/sys/devices/virtual/dmi/id/sys_vendor',
|
|
|
|
'bios_version': '/sys/devices/virtual/dmi/id/bios_version' }
|
|
|
|
bios_date = '/sys/devices/virtual/dmi/id/bios_date',
|
|
|
|
# From smolt and DMI spec
|
|
|
|
bios_version = '/sys/devices/virtual/dmi/id/bios_version'
|
|
|
|
# See http://www.dmtf.org/sites/default/files/standards/documents/DSP0134_2.7.0.pdf
|
|
|
|
)
|
|
|
|
|
|
|
|
# DMI SPEC -- http://www.dmtf.org/sites/default/files/standards/documents/DSP0134_2.7.0.pdf
|
|
|
|
FORM_FACTOR = [ "Unknown", "Other", "Unknown", "Desktop",
|
|
|
|
FORM_FACTOR = [ "Unknown", "Other", "Unknown", "Desktop",
|
|
|
|
"Low Profile Desktop", "Pizza Box", "Mini Tower", "Tower",
|
|
|
|
"Low Profile Desktop", "Pizza Box", "Mini Tower", "Tower",
|
|
|
|
"Portable", "Laptop", "Notebook", "Hand Held", "Docking Station",
|
|
|
|
"Portable", "Laptop", "Notebook", "Hand Held", "Docking Station",
|
|
|
@ -634,36 +636,36 @@ def run_setup(module):
|
|
|
|
# ruby-json is ALSO installed, include facter data in the JSON
|
|
|
|
# ruby-json is ALSO installed, include facter data in the JSON
|
|
|
|
|
|
|
|
|
|
|
|
if os.path.exists("/usr/bin/facter"):
|
|
|
|
if os.path.exists("/usr/bin/facter"):
|
|
|
|
cmd = subprocess.Popen("/usr/bin/facter --json", shell=True,
|
|
|
|
cmd = subprocess.Popen("/usr/bin/facter --json", shell=True,
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
out, err = cmd.communicate()
|
|
|
|
out, err = cmd.communicate()
|
|
|
|
facter = True
|
|
|
|
facter = True
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
facter_ds = json.loads(out)
|
|
|
|
facter_ds = json.loads(out)
|
|
|
|
except:
|
|
|
|
except:
|
|
|
|
facter = False
|
|
|
|
facter = False
|
|
|
|
if facter:
|
|
|
|
if facter:
|
|
|
|
for (k,v) in facter_ds.items():
|
|
|
|
for (k,v) in facter_ds.items():
|
|
|
|
setup_options["facter_%s" % k] = v
|
|
|
|
setup_options["facter_%s" % k] = v
|
|
|
|
|
|
|
|
|
|
|
|
# ditto for ohai, but just top level string keys
|
|
|
|
# ditto for ohai, but just top level string keys
|
|
|
|
# because it contains a lot of nested stuff we can't use for
|
|
|
|
# because it contains a lot of nested stuff we can't use for
|
|
|
|
# templating w/o making a nicer key for it (TODO)
|
|
|
|
# templating w/o making a nicer key for it (TODO)
|
|
|
|
|
|
|
|
|
|
|
|
if os.path.exists("/usr/bin/ohai"):
|
|
|
|
if os.path.exists("/usr/bin/ohai"):
|
|
|
|
cmd = subprocess.Popen("/usr/bin/ohai", shell=True,
|
|
|
|
cmd = subprocess.Popen("/usr/bin/ohai", shell=True,
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
out, err = cmd.communicate()
|
|
|
|
out, err = cmd.communicate()
|
|
|
|
ohai = True
|
|
|
|
ohai = True
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
ohai_ds = json.loads(out)
|
|
|
|
ohai_ds = json.loads(out)
|
|
|
|
except:
|
|
|
|
except:
|
|
|
|
ohai = False
|
|
|
|
ohai = False
|
|
|
|
if ohai:
|
|
|
|
if ohai:
|
|
|
|
for (k,v) in ohai_ds.items():
|
|
|
|
for (k,v) in ohai_ds.items():
|
|
|
|
if type(v) == str or type(v) == unicode:
|
|
|
|
if type(v) == str or type(v) == unicode:
|
|
|
|
k2 = "ohai_%s" % k
|
|
|
|
k2 = "ohai_%s" % k
|
|
|
|
setup_options[k2] = v
|
|
|
|
setup_options[k2] = v
|
|
|
|
|
|
|
|
|
|
|
|
setup_result = {}
|
|
|
|
setup_result = {}
|
|
|
|
setup_result['ansible_facts'] = setup_options
|
|
|
|
setup_result['ansible_facts'] = setup_options
|
|
|
@ -683,4 +685,3 @@ def main():
|
|
|
|
# this is magic, see lib/ansible/module_common.py
|
|
|
|
# this is magic, see lib/ansible/module_common.py
|
|
|
|
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
|
|
|
|
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
|
|
|
|
main()
|
|
|
|
main()
|
|
|
|
|
|
|
|
|
|
|
|