Class: Inspec::Resources::ApacheConf

Inherits:
Object
  • Object
show all
Includes:
FileReader, FindFiles
Defined in:
lib/resources/apache_conf.rb

Constant Summary

Constants included from FindFiles

FindFiles::TYPES

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from FileReader

#read_file_content

Methods included from FindFiles

#find_files, #find_files_or_warn

Constructor Details

#initialize(conf_path = nil) ⇒ ApacheConf

Returns a new instance of ApacheConf.



25
26
27
28
29
30
31
# File 'lib/resources/apache_conf.rb', line 25

def initialize(conf_path = nil)
  @conf_path = conf_path || default_conf_path
  @files_contents = {}
  @content = nil
  @params = nil
  read_content
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(name) ⇒ Object



46
47
48
49
50
51
52
# File 'lib/resources/apache_conf.rb', line 46

def method_missing(name)
  # ensure params are loaded
  @params || read_content

  # extract values
  @params[name.to_s] unless @params.nil?
end

Instance Attribute Details

#conf_pathObject (readonly)

Returns the value of attribute conf_path.



23
24
25
# File 'lib/resources/apache_conf.rb', line 23

def conf_path
  @conf_path
end

Instance Method Details

#conf_dirObject



131
132
133
134
135
136
137
138
139
140
141
# File 'lib/resources/apache_conf.rb', line 131

def conf_dir
  if inspec.os.debian?
    File.dirname(conf_path)
  else
    # On RHEL-based systems, the configuration is usually in a /conf directory
    # that contains the primary config file. We assume the "config path" is the
    # directory that contains the /conf directory, such as /etc/httpd, so that
    # the conf.d directory can be properly located.
    Pathname.new(File.dirname(conf_path)).parent.to_s
  end
end

#contentObject



33
34
35
# File 'lib/resources/apache_conf.rb', line 33

def content
  @content ||= read_content
end

#filter_comments(data) ⇒ Object



54
55
56
57
58
59
60
61
62
# File 'lib/resources/apache_conf.rb', line 54

def filter_comments(data)
  content = ''
  data.each_line do |line|
    if !line.match(/^\s*#/)
      content << line
    end
  end
  content
end

#include_files(params) ⇒ Object



109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'lib/resources/apache_conf.rb', line 109

def include_files(params)
  # see if there is more config files to include
  include_files = params['Include'] || []
  include_files_optional = params['IncludeOptional'] || []

  includes = []
  (include_files + include_files_optional).each do |f|
    id    = Pathname.new(f).absolute? ? f : File.join(conf_dir, f)
    files = find_files(id, depth: 1, type: 'file')
    files += find_files(id, depth: 1, type: 'link')

    includes.push(files) if files
  end

  # [].flatten! == nil
  includes.flatten! || []
end

#params(*opts) ⇒ Object



37
38
39
40
41
42
43
44
# File 'lib/resources/apache_conf.rb', line 37

def params(*opts)
  @params || read_content
  res = @params
  opts.each do |opt|
    res = res[opt] unless res.nil?
  end
  res
end

#read_contentObject



64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/resources/apache_conf.rb', line 64

def read_content
  @content = ''
  @params = {}

  read_file_content(conf_path)

  to_read = [conf_path]
  until to_read.empty?
    raw_conf = read_file(to_read[0])
    @content += raw_conf

    # An explaination of the below regular expression.
    # Creates two capture groups.
    # The first group captures the first group of non-whitespace character
    # surrounded whitespace characters.
    # The second group contains a conditional with a positive lookahead
    # (does the line end with one or more spaces?). If the lookahead succeeds
    # a non-greedy capture takes place, if it fails then a greedy capture takes place.
    # The regex is terminated by an expression that matches zero or more spaces.
    params = SimpleConfig.new(
      raw_conf,
      assignment_regex: /^\s*(\S+)\s+['"]*((?=.*\s+$).*?|.*?)['"]*\s*$/,
      multiple_values: true,
    ).params

    # Capture any characters between quotes that are not escaped in values
    params.values.map! do |value|
      value.map! do |sub_value|
        sub_value[/(?<=["|'])(?:\\.|[^"'\\])*(?=["|'])/] || sub_value
      end
    end

    @params.merge!(params)

    to_read = to_read.drop(1)
    to_read += include_files(params).find_all do |fp|
      not @files_contents.key? fp
    end
  end

  # fiter comments
  @content = filter_comments @content
  @content
end

#read_file(path) ⇒ Object



127
128
129
# File 'lib/resources/apache_conf.rb', line 127

def read_file(path)
  @files_contents[path] ||= read_file_content(path, true)
end

#to_sObject



143
144
145
# File 'lib/resources/apache_conf.rb', line 143

def to_s
  "Apache Config #{conf_path}"
end