import openbsd patches (#74056)

* add openbsd service info
* Create openbsd-service.yml
* Update var name
This commit is contained in:
chemsaf3 2021-03-30 16:17:40 +00:00 committed by GitHub
parent 6b33864a2c
commit 381bd1a575
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 56 additions and 7 deletions

View file

@ -0,0 +1,2 @@
minor_changes:
- service_facts - return service state information on OpenBSD.

View file

@ -0,0 +1,2 @@
bugfixes:
- OpenBSD module_utils - update sysctl variable name

View file

@ -132,7 +132,7 @@ class OpenBSDHardware(Hardware):
def get_processor_facts(self): def get_processor_facts(self):
cpu_facts = {} cpu_facts = {}
processor = [] processor = []
for i in range(int(self.sysctl['hw.ncpu'])): for i in range(int(self.sysctl['hw.ncpuonline'])):
processor.append(self.sysctl['hw.model']) processor.append(self.sysctl['hw.model'])
cpu_facts['processor'] = processor cpu_facts['processor'] = processor
@ -143,8 +143,8 @@ class OpenBSDHardware(Hardware):
# dmesg, however even those have proven to be unreliable. # dmesg, however even those have proven to be unreliable.
# So take a shortcut and report the logical number of processors in # So take a shortcut and report the logical number of processors in
# 'processor_count' and 'processor_cores' and leave it at that. # 'processor_count' and 'processor_cores' and leave it at that.
cpu_facts['processor_count'] = self.sysctl['hw.ncpu'] cpu_facts['processor_count'] = self.sysctl['hw.ncpuonline']
cpu_facts['processor_cores'] = self.sysctl['hw.ncpu'] cpu_facts['processor_cores'] = self.sysctl['hw.ncpuonline']
return cpu_facts return cpu_facts

View file

@ -55,14 +55,14 @@ ansible_facts:
source: source:
description: description:
- Init system of the service. - Init system of the service.
- One of C(systemd), C(sysv), C(upstart), C(src). - One of C(rcctl), C(systemd), C(sysv), C(upstart), C(src).
returned: always returned: always
type: str type: str
sample: sysv sample: sysv
state: state:
description: description:
- State of the service. - State of the service.
- Either C(running), C(stopped), or C(unknown). - Either C(failed), C(running), C(stopped), or C(unknown).
returned: always returned: always
type: str type: str
sample: running sample: running
@ -70,7 +70,7 @@ ansible_facts:
description: description:
- State of the service. - State of the service.
- Either C(enabled), C(disabled), C(static), C(indirect) or C(unknown). - Either C(enabled), C(disabled), C(static), C(indirect) or C(unknown).
returned: systemd systems or RedHat/SUSE flavored sysvinit/upstart returned: systemd systems or RedHat/SUSE flavored sysvinit/upstart or OpenBSD
type: str type: str
sample: enabled sample: enabled
name: name:
@ -260,10 +260,55 @@ class AIXScanService(BaseService):
return services return services
class OpenBSDScanService(BaseService):
def query_rcctl(self, cmd):
svcs = []
rc, stdout, stderr = self.module.run_command("%s ls %s" % (self.rcctl_path, cmd))
if 'needs root privileges' in stderr.lower():
self.incomplete_warning = True
return []
for svc in stdout.split('\n'):
if svc == '':
continue
else:
svcs.append(svc)
return svcs
def gather_services(self):
services = {}
self.rcctl_path = self.module.get_bin_path("rcctl")
if self.rcctl_path is None:
return None
for svc in self.query_rcctl('all'):
services[svc] = {'name': svc, 'source': 'rcctl'}
for svc in self.query_rcctl('on'):
services[svc].update({'status': 'enabled'})
for svc in self.query_rcctl('started'):
services[svc].update({'state': 'running'})
# Based on the list of services that are enabled, determine which are disabled
[services[svc].update({'status': 'disabled'}) for svc in services if services[svc].get('status') is None]
# and do the same for those are aren't running
[services[svc].update({'state': 'stopped'}) for svc in services if services[svc].get('state') is None]
# Override the state for services which are marked as 'failed'
for svc in self.query_rcctl('failed'):
services[svc].update({'state': 'failed'})
return services
def main(): def main():
module = AnsibleModule(argument_spec=dict(), supports_check_mode=True) module = AnsibleModule(argument_spec=dict(), supports_check_mode=True)
module.run_command_environ_update = dict(LANG="C", LC_ALL="C") module.run_command_environ_update = dict(LANG="C", LC_ALL="C")
service_modules = (ServiceScanService, SystemctlScanService, AIXScanService) service_modules = (ServiceScanService, SystemctlScanService, AIXScanService, OpenBSDScanService)
all_services = {} all_services = {}
incomplete_warning = False incomplete_warning = False
for svc_module in service_modules: for svc_module in service_modules: