mirror of
https://github.com/inspec/inspec
synced 2025-01-05 09:49:02 +00:00
Merge pull request #846 from chef/chris-rock/fix-xinetd-single-entry
Handle xinetd config with only one entry
This commit is contained in:
commit
968e87b6e3
3 changed files with 24 additions and 2 deletions
|
@ -66,17 +66,26 @@ module Inspec::Resources
|
|||
def read_params
|
||||
return {} if read_content.nil?
|
||||
flat_params = parse_xinetd(read_content)
|
||||
# we need to map service data in order to use it with filtertable
|
||||
params = { 'services' => {} }
|
||||
|
||||
# parse services that were defined:
|
||||
# map services that were defined and map it to the service hash
|
||||
flat_params.each do |k, v|
|
||||
name = k[/^service (.+)$/, 1]
|
||||
# its not a service, no change required
|
||||
if name.nil?
|
||||
params[k] = v
|
||||
# handle service entries
|
||||
else
|
||||
# store service
|
||||
params['services'][name] = v
|
||||
|
||||
# add the service identifier to its parameters
|
||||
if v.is_a?(Array)
|
||||
v.each { |service| service.params['service'] = name }
|
||||
else
|
||||
v.params['service'] = name
|
||||
end
|
||||
end
|
||||
end
|
||||
params
|
||||
|
|
|
@ -179,6 +179,7 @@ module SolarisNetstatParser
|
|||
end
|
||||
end
|
||||
|
||||
# This parser for xinetd (extended Internet daemon) configuration files
|
||||
module XinetdParser
|
||||
def xinetd_include_dir(dir)
|
||||
return [] if dir.nil?
|
||||
|
@ -198,10 +199,12 @@ module XinetdParser
|
|||
simple_conf = []
|
||||
rest = raw
|
||||
until rest.empty?
|
||||
# extract content line
|
||||
nl = rest.index("\n") || (rest.length-1)
|
||||
comment = rest.index('#') || (rest.length-1)
|
||||
dst_idx = (comment < nl) ? comment : nl
|
||||
inner_line = (dst_idx == 0) ? '' : rest[0..dst_idx-1].strip
|
||||
# update unparsed content
|
||||
rest = rest[nl+1..-1]
|
||||
next if inner_line.empty?
|
||||
|
||||
|
@ -213,6 +216,7 @@ module XinetdParser
|
|||
simple_conf = []
|
||||
rest = rest[rest.index("\n")+1..-1]
|
||||
elsif cur_group.nil?
|
||||
# parse all included files
|
||||
others = xinetd_include_dir(inner_line[/includedir (.+)/, 1])
|
||||
|
||||
# complex merging of included configurations, as multiple services
|
||||
|
|
|
@ -57,4 +57,13 @@ describe 'Inspec::Resources::XinetdConf' do
|
|||
_(resource.enabled?).must_equal false
|
||||
end
|
||||
end
|
||||
|
||||
describe 'with single services and no child configs' do
|
||||
let (:resource) { load_resource('xinetd_conf', '/etc/xinetd.d/chargen-stream') }
|
||||
|
||||
it 'checks if all are disabled on one disabled service' do
|
||||
one = resource.ids('chargen-stream')
|
||||
_(one.disabled?).must_equal true
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue