facter 4.2.1 → 4.2.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (43) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +202 -0
  3. data/lib/facter/custom_facts/core/execution/base.rb +14 -9
  4. data/lib/facter/custom_facts/core/execution.rb +25 -17
  5. data/lib/facter/custom_facts/core/file_loader.rb +0 -1
  6. data/lib/facter/custom_facts/core/legacy_facter.rb +0 -2
  7. data/lib/facter/custom_facts/core/resolvable.rb +1 -1
  8. data/lib/facter/custom_facts/util/collection.rb +6 -4
  9. data/lib/facter/custom_facts/util/confine.rb +9 -3
  10. data/lib/facter/custom_facts/util/directory_loader.rb +18 -6
  11. data/lib/facter/custom_facts/util/fact.rb +12 -10
  12. data/lib/facter/custom_facts/util/loader.rb +7 -3
  13. data/lib/facter/custom_facts/util/parser.rb +8 -2
  14. data/lib/facter/custom_facts/util/resolution.rb +5 -1
  15. data/lib/facter/facts/windows/os/windows/display_version.rb +19 -0
  16. data/lib/facter/framework/cli/cli.rb +4 -0
  17. data/lib/facter/framework/core/fact/internal/internal_fact_manager.rb +0 -2
  18. data/lib/facter/framework/core/fact_loaders/fact_loader.rb +0 -1
  19. data/lib/facter/framework/core/fact_manager.rb +14 -1
  20. data/lib/facter/framework/core/options/option_store.rb +3 -1
  21. data/lib/facter/framework/logging/logger.rb +61 -0
  22. data/lib/facter/framework/parsers/query_parser.rb +1 -4
  23. data/lib/facter/models/resolved_fact.rb +4 -0
  24. data/lib/facter/resolvers/aix/disks.rb +1 -1
  25. data/lib/facter/resolvers/aix/mountpoints.rb +1 -1
  26. data/lib/facter/resolvers/aix/partitions.rb +1 -1
  27. data/lib/facter/resolvers/aix/processors.rb +2 -1
  28. data/lib/facter/resolvers/linux/networking.rb +0 -1
  29. data/lib/facter/resolvers/lsb_release.rb +1 -2
  30. data/lib/facter/resolvers/macosx/{processor.rb → processors.rb} +21 -21
  31. data/lib/facter/resolvers/networking.rb +3 -1
  32. data/lib/facter/resolvers/os_release.rb +7 -4
  33. data/lib/facter/resolvers/partitions.rb +1 -3
  34. data/lib/facter/resolvers/windows/product_release.rb +13 -4
  35. data/lib/facter/util/aix/info_extractor.rb +60 -9
  36. data/lib/facter/util/facts/windows_release_finder.rb +4 -2
  37. data/lib/facter/util/linux/dhcp.rb +4 -1
  38. data/lib/facter/util/linux/socket_parser.rb +17 -2
  39. data/lib/facter/util/resolvers/http.rb +3 -0
  40. data/lib/facter/version.rb +1 -1
  41. data/lib/facter.rb +31 -18
  42. metadata +12 -5
  43. data/lib/facter/custom_facts/core/logging.rb +0 -203
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 7d82b5638d66725eb654bb71a40be9e8faf9f98ab17200bc3340ec2a88416076
4
- data.tar.gz: 2f6d868d28453ddf1fce7ce5cd24efce4365f5f7383980b6857f4771f7e8e22a
3
+ metadata.gz: 5fa80567c0c01b5ceed0181b78f9e9e813d4eea3c70905733ba1aa5e9298ad15
4
+ data.tar.gz: 1541ade4a87eacbbaa569c0ace340312dfde0c8299b12cd1973d8861449a798f
5
5
  SHA512:
6
- metadata.gz: 8a81868164b70e5f172354f3666c2d3c7cb8f8bf52ccbb4b8bd150ce097d771ad6c2df99f43401311d089eac5cb7404c90ec8cc7c2d074c062b7f2a66249be0f
7
- data.tar.gz: 7de563f91031e60fd404bd00843f38a73c9782d1b816a997975db71bc0bca4a7302190fbded94559e0b1bc8613c32d950749fd2578b75d1518826d4b09958465
6
+ metadata.gz: ea3608714cc012b4f64de7f4b472c904152e82387b980d7b3740a318b3b500228dc2e57a41bab27c113d7d6cb9ce8985394d69db2c6ef49d0fd1483b0608b220
7
+ data.tar.gz: 33f8a676b5a70c964f90f2576e4b1a65d5e2b27c9b2b09edd12145f77da20f303ab295ee3de1998aed74eff967e4765ac0ad48a885a9ffbe175bbda2f6ce3b20
data/LICENSE ADDED
@@ -0,0 +1,202 @@
1
+
2
+ Apache License
3
+ Version 2.0, January 2004
4
+ http://www.apache.org/licenses/
5
+
6
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7
+
8
+ 1. Definitions.
9
+
10
+ "License" shall mean the terms and conditions for use, reproduction,
11
+ and distribution as defined by Sections 1 through 9 of this document.
12
+
13
+ "Licensor" shall mean the copyright owner or entity authorized by
14
+ the copyright owner that is granting the License.
15
+
16
+ "Legal Entity" shall mean the union of the acting entity and all
17
+ other entities that control, are controlled by, or are under common
18
+ control with that entity. For the purposes of this definition,
19
+ "control" means (i) the power, direct or indirect, to cause the
20
+ direction or management of such entity, whether by contract or
21
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
22
+ outstanding shares, or (iii) beneficial ownership of such entity.
23
+
24
+ "You" (or "Your") shall mean an individual or Legal Entity
25
+ exercising permissions granted by this License.
26
+
27
+ "Source" form shall mean the preferred form for making modifications,
28
+ including but not limited to software source code, documentation
29
+ source, and configuration files.
30
+
31
+ "Object" form shall mean any form resulting from mechanical
32
+ transformation or translation of a Source form, including but
33
+ not limited to compiled object code, generated documentation,
34
+ and conversions to other media types.
35
+
36
+ "Work" shall mean the work of authorship, whether in Source or
37
+ Object form, made available under the License, as indicated by a
38
+ copyright notice that is included in or attached to the work
39
+ (an example is provided in the Appendix below).
40
+
41
+ "Derivative Works" shall mean any work, whether in Source or Object
42
+ form, that is based on (or derived from) the Work and for which the
43
+ editorial revisions, annotations, elaborations, or other modifications
44
+ represent, as a whole, an original work of authorship. For the purposes
45
+ of this License, Derivative Works shall not include works that remain
46
+ separable from, or merely link (or bind by name) to the interfaces of,
47
+ the Work and Derivative Works thereof.
48
+
49
+ "Contribution" shall mean any work of authorship, including
50
+ the original version of the Work and any modifications or additions
51
+ to that Work or Derivative Works thereof, that is intentionally
52
+ submitted to Licensor for inclusion in the Work by the copyright owner
53
+ or by an individual or Legal Entity authorized to submit on behalf of
54
+ the copyright owner. For the purposes of this definition, "submitted"
55
+ means any form of electronic, verbal, or written communication sent
56
+ to the Licensor or its representatives, including but not limited to
57
+ communication on electronic mailing lists, source code control systems,
58
+ and issue tracking systems that are managed by, or on behalf of, the
59
+ Licensor for the purpose of discussing and improving the Work, but
60
+ excluding communication that is conspicuously marked or otherwise
61
+ designated in writing by the copyright owner as "Not a Contribution."
62
+
63
+ "Contributor" shall mean Licensor and any individual or Legal Entity
64
+ on behalf of whom a Contribution has been received by Licensor and
65
+ subsequently incorporated within the Work.
66
+
67
+ 2. Grant of Copyright License. Subject to the terms and conditions of
68
+ this License, each Contributor hereby grants to You a perpetual,
69
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70
+ copyright license to reproduce, prepare Derivative Works of,
71
+ publicly display, publicly perform, sublicense, and distribute the
72
+ Work and such Derivative Works in Source or Object form.
73
+
74
+ 3. Grant of Patent License. Subject to the terms and conditions of
75
+ this License, each Contributor hereby grants to You a perpetual,
76
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77
+ (except as stated in this section) patent license to make, have made,
78
+ use, offer to sell, sell, import, and otherwise transfer the Work,
79
+ where such license applies only to those patent claims licensable
80
+ by such Contributor that are necessarily infringed by their
81
+ Contribution(s) alone or by combination of their Contribution(s)
82
+ with the Work to which such Contribution(s) was submitted. If You
83
+ institute patent litigation against any entity (including a
84
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
85
+ or a Contribution incorporated within the Work constitutes direct
86
+ or contributory patent infringement, then any patent licenses
87
+ granted to You under this License for that Work shall terminate
88
+ as of the date such litigation is filed.
89
+
90
+ 4. Redistribution. You may reproduce and distribute copies of the
91
+ Work or Derivative Works thereof in any medium, with or without
92
+ modifications, and in Source or Object form, provided that You
93
+ meet the following conditions:
94
+
95
+ (a) You must give any other recipients of the Work or
96
+ Derivative Works a copy of this License; and
97
+
98
+ (b) You must cause any modified files to carry prominent notices
99
+ stating that You changed the files; and
100
+
101
+ (c) You must retain, in the Source form of any Derivative Works
102
+ that You distribute, all copyright, patent, trademark, and
103
+ attribution notices from the Source form of the Work,
104
+ excluding those notices that do not pertain to any part of
105
+ the Derivative Works; and
106
+
107
+ (d) If the Work includes a "NOTICE" text file as part of its
108
+ distribution, then any Derivative Works that You distribute must
109
+ include a readable copy of the attribution notices contained
110
+ within such NOTICE file, excluding those notices that do not
111
+ pertain to any part of the Derivative Works, in at least one
112
+ of the following places: within a NOTICE text file distributed
113
+ as part of the Derivative Works; within the Source form or
114
+ documentation, if provided along with the Derivative Works; or,
115
+ within a display generated by the Derivative Works, if and
116
+ wherever such third-party notices normally appear. The contents
117
+ of the NOTICE file are for informational purposes only and
118
+ do not modify the License. You may add Your own attribution
119
+ notices within Derivative Works that You distribute, alongside
120
+ or as an addendum to the NOTICE text from the Work, provided
121
+ that such additional attribution notices cannot be construed
122
+ as modifying the License.
123
+
124
+ You may add Your own copyright statement to Your modifications and
125
+ may provide additional or different license terms and conditions
126
+ for use, reproduction, or distribution of Your modifications, or
127
+ for any such Derivative Works as a whole, provided Your use,
128
+ reproduction, and distribution of the Work otherwise complies with
129
+ the conditions stated in this License.
130
+
131
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
132
+ any Contribution intentionally submitted for inclusion in the Work
133
+ by You to the Licensor shall be under the terms and conditions of
134
+ this License, without any additional terms or conditions.
135
+ Notwithstanding the above, nothing herein shall supersede or modify
136
+ the terms of any separate license agreement you may have executed
137
+ with Licensor regarding such Contributions.
138
+
139
+ 6. Trademarks. This License does not grant permission to use the trade
140
+ names, trademarks, service marks, or product names of the Licensor,
141
+ except as required for reasonable and customary use in describing the
142
+ origin of the Work and reproducing the content of the NOTICE file.
143
+
144
+ 7. Disclaimer of Warranty. Unless required by applicable law or
145
+ agreed to in writing, Licensor provides the Work (and each
146
+ Contributor provides its Contributions) on an "AS IS" BASIS,
147
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148
+ implied, including, without limitation, any warranties or conditions
149
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150
+ PARTICULAR PURPOSE. You are solely responsible for determining the
151
+ appropriateness of using or redistributing the Work and assume any
152
+ risks associated with Your exercise of permissions under this License.
153
+
154
+ 8. Limitation of Liability. In no event and under no legal theory,
155
+ whether in tort (including negligence), contract, or otherwise,
156
+ unless required by applicable law (such as deliberate and grossly
157
+ negligent acts) or agreed to in writing, shall any Contributor be
158
+ liable to You for damages, including any direct, indirect, special,
159
+ incidental, or consequential damages of any character arising as a
160
+ result of this License or out of the use or inability to use the
161
+ Work (including but not limited to damages for loss of goodwill,
162
+ work stoppage, computer failure or malfunction, or any and all
163
+ other commercial damages or losses), even if such Contributor
164
+ has been advised of the possibility of such damages.
165
+
166
+ 9. Accepting Warranty or Additional Liability. While redistributing
167
+ the Work or Derivative Works thereof, You may choose to offer,
168
+ and charge a fee for, acceptance of support, warranty, indemnity,
169
+ or other liability obligations and/or rights consistent with this
170
+ License. However, in accepting such obligations, You may act only
171
+ on Your own behalf and on Your sole responsibility, not on behalf
172
+ of any other Contributor, and only if You agree to indemnify,
173
+ defend, and hold each Contributor harmless for any liability
174
+ incurred by, or claims asserted against, such Contributor by reason
175
+ of your accepting any such warranty or additional liability.
176
+
177
+ END OF TERMS AND CONDITIONS
178
+
179
+ APPENDIX: How to apply the Apache License to your work.
180
+
181
+ To apply the Apache License to your work, attach the following
182
+ boilerplate notice, with the fields enclosed by brackets "{}"
183
+ replaced with your own identifying information. (Don't include
184
+ the brackets!) The text should be enclosed in the appropriate
185
+ comment syntax for the file format. We also recommend that a
186
+ file or class name and description of purpose be included on the
187
+ same "printed page" as the copyright notice for easier
188
+ identification within third-party archives.
189
+
190
+ Copyright {yyyy} {name of copyright owner}
191
+
192
+ Licensed under the Apache License, Version 2.0 (the "License");
193
+ you may not use this file except in compliance with the License.
194
+ You may obtain a copy of the License at
195
+
196
+ http://www.apache.org/licenses/LICENSE-2.0
197
+
198
+ Unless required by applicable law or agreed to in writing, software
199
+ distributed under the License is distributed on an "AS IS" BASIS,
200
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201
+ See the License for the specific language governing permissions and
202
+ limitations under the License.
@@ -42,7 +42,7 @@ module Facter
42
42
  end
43
43
 
44
44
  def execute(command, options = {})
45
- on_fail, expand, logger, time_limit = extract_options(options)
45
+ on_fail, expand, logger, timeout = extract_options(options)
46
46
 
47
47
  expanded_command = if !expand && builtin_command?(command) || logger
48
48
  command
@@ -59,12 +59,12 @@ module Facter
59
59
  return on_fail
60
60
  end
61
61
 
62
- out, = execute_command(expanded_command, on_fail, logger, time_limit)
62
+ out, = execute_command(expanded_command, on_fail, logger, timeout)
63
63
  out
64
64
  end
65
65
 
66
- def execute_command(command, on_fail = nil, logger = nil, time_limit = nil)
67
- time_limit ||= 300
66
+ def execute_command(command, on_fail = nil, logger = nil, timeout = nil)
67
+ timeout ||= 300
68
68
  begin
69
69
  # Set LC_ALL and LANG to force i18n to C for the duration of this exec;
70
70
  # this ensures that any code that parses the
@@ -78,12 +78,12 @@ module Facter
78
78
  out_reader = Thread.new { stdout.read }
79
79
  err_reader = Thread.new { stderr.read }
80
80
  begin
81
- Timeout.timeout(time_limit) do
81
+ Timeout.timeout(timeout) do
82
82
  stdout_messages << out_reader.value
83
83
  stderr_messages << err_reader.value
84
84
  end
85
85
  rescue Timeout::Error
86
- message = "Timeout encounter after #{time_limit}s, killing process with pid: #{pid}"
86
+ message = "Timeout encounter after #{timeout}s, killing process with pid: #{pid}"
87
87
  Process.kill('KILL', pid)
88
88
  on_fail == :raise ? (raise StandardError, message) : @log.debug(message)
89
89
  ensure
@@ -114,10 +114,15 @@ module Facter
114
114
  on_fail = options.fetch(:on_fail, :raise)
115
115
  expand = options.fetch(:expand, true)
116
116
  logger = options[:logger]
117
- time_limit = options[:limit].to_i
118
- time_limit = time_limit.positive? ? time_limit : nil
117
+ timeout = (options[:timeout] || options[:time_limit] || options[:limit]).to_i
118
+ timeout = timeout.positive? ? timeout : nil
119
119
 
120
- [on_fail, expand, logger, time_limit]
120
+ extra_keys = options.keys - %i[on_fail expand logger timeout]
121
+ unless extra_keys.empty?
122
+ @log.warn("Unexpected key passed to Facter::Core::Execution.execute option: #{options.keys.join(',')}")
123
+ end
124
+
125
+ [on_fail, expand, logger, timeout]
121
126
  end
122
127
 
123
128
  def log_stderr(msg, command, logger)
@@ -15,9 +15,9 @@ module Facter
15
15
 
16
16
  module_function
17
17
 
18
- # Returns the locations to be searched when looking for a binary. This
19
- # is currently determined by the +PATH+ environment variable plus
20
- # `/sbin` and `/usr/sbin` when run on unix
18
+ # Returns the locations to be searched when looking for a binary. This is
19
+ # currently determined by the +PATH+ environment variable plus `/sbin`
20
+ # and `/usr/sbin` when run on unix
21
21
  #
22
22
  # @return [Array<String>] The paths to be searched for binaries
23
23
  #
@@ -27,8 +27,9 @@ module Facter
27
27
  end
28
28
 
29
29
  # Determines the full path to a binary. If the supplied filename does not
30
- # already describe an absolute path then different locations (determined
31
- # by {search_paths}) will be searched for a match.
30
+ # already describe an absolute path then different locations (determined
31
+ # by {search_paths}) will be searched for a match.
32
+ #
32
33
  # @param bin [String] The executable to locate
33
34
  #
34
35
  # @return [String/nil] The full path to the executable or nil if not
@@ -40,7 +41,8 @@ module Facter
40
41
  end
41
42
 
42
43
  # Determine in a platform-specific way whether a path is absolute. This
43
- # defaults to the local platform if none is specified.
44
+ # defaults to the local platform if none is specified.
45
+ #
44
46
  # @param path [String] The path to check
45
47
 
46
48
  # @param platform [:posix/:windows/nil] The platform logic to use
@@ -58,8 +60,9 @@ module Facter
58
60
  end
59
61
 
60
62
  # Given a command line, this returns the command line with the
61
- # executable written as an absolute path. If the executable contains
62
- # spaces, it has to be put in double quotes to be properly recognized.
63
+ # executable written as an absolute path. If the executable contains
64
+ # spaces, it has to be put in double quotes to be properly recognized.
65
+ #
63
66
  # @param command [String] the command line
64
67
  #
65
68
  # @return [String/nil] The command line with the executable's path
@@ -71,8 +74,9 @@ module Facter
71
74
  end
72
75
 
73
76
  # Overrides environment variables within a block of code. The
74
- # specified values will be set for the duration of the block, after
75
- # which the original values (if any) will be restored.
77
+ # specified values will be set for the duration of the block, after
78
+ # which the original values (if any) will be restored.
79
+ #
76
80
  # @param values [Hash<String=>String>] A hash of the environment
77
81
  # variables to override
78
82
  #
@@ -84,6 +88,7 @@ module Facter
84
88
  end
85
89
 
86
90
  # Try to execute a command and return the output.
91
+ #
87
92
  # @param command [String] Command to run
88
93
  #
89
94
  # @return [String/nil] Output of the program, or nil if the command does
@@ -96,16 +101,18 @@ module Facter
96
101
  end
97
102
 
98
103
  # Execute a command and return the output of that program.
104
+ #
99
105
  # @param command [String] Command to run
100
106
  #
101
107
  # @param options [Hash] Hash with options for the command
102
108
  #
103
- # Options accepted values :on_fail How to behave when the command could
109
+ # @option options [Object] :on_fail How to behave when the command could
104
110
  # not be run. Specifying :raise will raise an error, anything else will
105
111
  # return that object on failure. Default is :raise.
106
- # :logger Optional logger used to log the command's stderr.
107
- # :time_limit Optional time out for the specified command. If no time_limit is passed,
108
- # a default of 300 seconds is used.
112
+ # @option options [Object] :logger Optional logger used to log the
113
+ # command's stderr.
114
+ # @option options :timeout Optional time out for the specified
115
+ # command. If no timeout is passed, a default of 300 seconds is used.
109
116
  #
110
117
  # @raise [Facter::Core::Execution::ExecutionFailure] If the command does
111
118
  # not exist or could not be executed and :on_fail is set to :raise
@@ -119,13 +126,14 @@ module Facter
119
126
  end
120
127
 
121
128
  # Execute a command and return the stdout and stderr of that program.
129
+ #
122
130
  # @param command [String] Command to run
123
131
  #
124
132
  # @param on_fail[Object] How to behave when the command could
125
133
  # not be run. Specifying :raise will raise an error, anything else will
126
134
  # return that object on failure. Default is :raise.
127
135
  # @param logger Optional logger used to log the command's stderr.
128
- # @param time_limit Optional time out for the specified command. If no time_limit is passed,
136
+ # @param timeout Optional time out for the specified command. If no timeout is passed,
129
137
  # a default of 300 seconds is used.
130
138
  #
131
139
  # @raise [Facter::Core::Execution::ExecutionFailure] If the command does
@@ -135,8 +143,8 @@ module Facter
135
143
  # :on_fail if command execution failed and :on_fail was specified.
136
144
  #
137
145
  # @api private
138
- def execute_command(command, on_fail = nil, logger = nil, time_limit = nil)
139
- @@impl.execute_command(command, on_fail, logger, time_limit)
146
+ def execute_command(command, on_fail = nil, logger = nil, timeout = nil)
147
+ @@impl.execute_command(command, on_fail, logger, timeout)
140
148
  end
141
149
 
142
150
  class ExecutionFailure < StandardError; end
@@ -1,6 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'facter/custom_facts/core/logging'
4
3
  require 'facter/custom_facts/core/legacy_facter'
5
4
  require 'facter/custom_facts/util/fact'
6
5
  require 'facter/custom_facts/util/collection'
@@ -38,8 +38,6 @@ module LegacyFacter
38
38
  include Comparable
39
39
  include Enumerable
40
40
 
41
- extend LegacyFacter::Core::Logging
42
-
43
41
  # module methods
44
42
 
45
43
  # Accessor for the collection object which holds all the facts
@@ -103,7 +103,7 @@ module LegacyFacter
103
103
 
104
104
  finishtime = Time.now.to_f
105
105
  ms = (finishtime - starttime) * 1000
106
- LegacyFacter.show_time format('%<qn>s: %<ms>.2fms', qn: qualified_name, ms: ms)
106
+ Facter::Log.show_time format('%<qn>s: %<ms>.2fms', qn: qualified_name, ms: ms)
107
107
  end
108
108
 
109
109
  def qualified_name
@@ -32,7 +32,7 @@ module LegacyFacter
32
32
 
33
33
  fact
34
34
  rescue StandardError => e
35
- Facter.log_exception(e, "Unable to add fact #{name}: #{e}")
35
+ log.log_exception("Unable to add fact #{name}: #{e}")
36
36
  end
37
37
 
38
38
  # Add a resolution mechanism for a named fact. This does not distinguish
@@ -71,9 +71,7 @@ module LegacyFacter
71
71
  # Try HARDER
72
72
  internal_loader.load_all unless @facts[name]
73
73
 
74
- if @facts.empty?
75
- LegacyFacter.warnonce("No facts loaded from #{internal_loader.search_path.join(File::PATH_SEPARATOR)}")
76
- end
74
+ log.warnonce("No facts loaded from #{internal_loader.search_path.join(File::PATH_SEPARATOR)}") if @facts.empty?
77
75
 
78
76
  @facts[name]
79
77
  end
@@ -181,6 +179,10 @@ module LegacyFacter
181
179
  @external_facts_loaded = true
182
180
  external_loader.load(self)
183
181
  end
182
+
183
+ def log
184
+ @log ||= Facter::Log.new(self)
185
+ end
184
186
  end
185
187
  end
186
188
  end
@@ -41,13 +41,13 @@ module LegacyFacter
41
41
  begin
42
42
  return !!@block.call
43
43
  rescue StandardError => e
44
- LegacyFacter.debug "Confine raised #{e.class} #{e}"
44
+ log.debug "Confine raised #{e.class} #{e}"
45
45
  return false
46
46
  end
47
47
  end
48
48
 
49
49
  unless (fact = Facter[@fact])
50
- LegacyFacter.debug format('No fact for %<fact>s', fact: @fact)
50
+ log.debug format('No fact for %<fact>s', fact: @fact)
51
51
  return false
52
52
  end
53
53
  value = convert(fact.value)
@@ -58,13 +58,19 @@ module LegacyFacter
58
58
  begin
59
59
  return !!@block.call(value)
60
60
  rescue StandardError => e
61
- LegacyFacter.debug "Confine raised #{e.class} #{e}"
61
+ log.debug "Confine raised #{e.class} #{e}"
62
62
  return false
63
63
  end
64
64
  end
65
65
 
66
66
  @values.any? { |v| convert(v) === value }
67
67
  end
68
+
69
+ private
70
+
71
+ def log
72
+ @log ||= Facter::Log.new(self)
73
+ end
68
74
  end
69
75
  end
70
76
  end
@@ -52,6 +52,10 @@ module LegacyFacter
52
52
 
53
53
  private
54
54
 
55
+ def log
56
+ @log ||= Facter::Log.new(self)
57
+ end
58
+
55
59
  def load_directory_entries(_collection)
56
60
  cm = Facter::CacheManager.new
57
61
  facts = []
@@ -87,18 +91,26 @@ module LegacyFacter
87
91
  data = resolve_fact(fact, parser)
88
92
 
89
93
  if data == false
90
- LegacyFacter.warn "Could not interpret fact file #{fact.file}"
94
+ log.warn "Could not interpret fact file #{fact.file}"
91
95
  elsif (data == {}) || data.nil?
92
- @log.debug("Fact file #{fact.file} was parsed but no key=>value data was returned")
96
+ log.debug("Fact file #{fact.file} was parsed but no key=>value data was returned")
93
97
  else
94
- data.each do |p, v|
95
- collection.add(p, value: v, fact_type: :external,
96
- file: fact.file) { has_weight(weight) }
97
- end
98
+ add_data(data, collection, fact, weight)
98
99
  end
99
100
  end
100
101
  end
101
102
 
103
+ def add_data(data, collection, fact, weight)
104
+ data.each do |key, value|
105
+ collection.add(
106
+ key,
107
+ value: value,
108
+ fact_type: :external,
109
+ file: fact.file
110
+ ) { has_weight(weight) }
111
+ end
112
+ end
113
+
102
114
  def resolve_fact(fact, parser)
103
115
  data = nil
104
116
  fact_name = File.basename(fact.file)
@@ -47,8 +47,6 @@ module Facter
47
47
  @used_resolution_weight = 0
48
48
 
49
49
  @value = nil
50
-
51
- @log = Facter::Log.new(self)
52
50
  end
53
51
 
54
52
  # Adds a new {Facter::Util::Resolution resolution}. This requires a
@@ -87,8 +85,8 @@ module Facter
87
85
 
88
86
  resolve
89
87
  rescue StandardError => e
90
- LegacyFacter
91
- .log_exception(e, "Unable to add resolve #{resolution_name.inspect} for fact #{@name}: #{e.message}")
88
+ log.log_exception("Unable to add resolve #{resolution_name.inspect} for fact #{@name}: #{e.message}")
89
+ nil
92
90
  end
93
91
 
94
92
  # Retrieve an existing resolution by name
@@ -122,7 +120,7 @@ module Facter
122
120
  return @value if @value
123
121
 
124
122
  if @resolves.empty?
125
- LegacyFacter.debug format('No resolves for %<name>s', name: @name)
123
+ log.debug format('No resolves for %<name>s', name: @name)
126
124
  return nil
127
125
  end
128
126
 
@@ -147,12 +145,16 @@ module Facter
147
145
  def extract_ldapname_option!(options)
148
146
  return unless options[:ldapname]
149
147
 
150
- LegacyFacter.warnonce('ldapname is deprecated and will be removed in a future version')
148
+ log.warnonce('ldapname is deprecated and will be removed in a future version')
151
149
  self.ldapname = options.delete(:ldapname)
152
150
  end
153
151
 
154
152
  private
155
153
 
154
+ def log
155
+ @log ||= Facter::Log.new(self)
156
+ end
157
+
156
158
  def resolve_value
157
159
  return Facter.core_value(name) if @value.nil?
158
160
 
@@ -222,18 +224,18 @@ module Facter
222
224
 
223
225
  def log_fact_path(resolve)
224
226
  fact = resolve.fact
225
- @log.debug("#{resolve.fact_type} fact #{fact.name} got resolved from: #{fact.location}")
227
+ log.debug("#{resolve.fact_type} fact #{fact.name} got resolved from: #{fact.location}")
226
228
  end
227
229
 
228
230
  def announce_when_no_suitable_resolution(resolutions)
229
231
  return unless resolutions.empty?
230
232
 
231
- LegacyFacter.debug format('Found no suitable resolves of %<resolver_length> for %<name>s',
232
- resolver_length: @resolves.length, name: @name)
233
+ log.debug format('Found no suitable resolves of %<resolver_length> for %<name>s',
234
+ resolver_length: @resolves.length, name: @name)
233
235
  end
234
236
 
235
237
  def announce_when_no_value_found(value)
236
- LegacyFacter.debug(format('value for %<name>s is still nil', name: @name)) if value.nil?
238
+ log.debug(format('value for %<name>s is still nil', name: @name)) if value.nil?
237
239
  end
238
240
 
239
241
  def create_or_return_resolution(resolution_name, resolution_type)
@@ -78,7 +78,7 @@ module LegacyFacter
78
78
  if valid_search_path?(path)
79
79
  search_paths << path
80
80
  else
81
- LegacyFacter.warn "Excluding #{path} from search path. Fact file paths must be an absolute directory"
81
+ log.debug "Excluding #{path} from search path. Fact file paths must be an absolute directory"
82
82
  end
83
83
  end
84
84
 
@@ -89,6 +89,10 @@ module LegacyFacter
89
89
 
90
90
  private
91
91
 
92
+ def log
93
+ @log ||= Facter::Log.new(self)
94
+ end
95
+
92
96
  # Validate that the given path is valid, ie it is an absolute path.
93
97
  #
94
98
  # @api private
@@ -137,13 +141,13 @@ module LegacyFacter
137
141
  # Skip anything that doesn't match our regex.
138
142
  next unless name =~ /^facter_?(\w+)$/i
139
143
 
140
- env_name = Regexp.last_match(1)
144
+ env_name = Regexp.last_match(1).downcase
141
145
 
142
146
  # If a fact name was specified, skip anything that doesn't
143
147
  # match it.
144
148
  next if fact && (env_name != fact)
145
149
 
146
- LegacyFacter.add(Regexp.last_match(1), fact_type: :external, is_env: true) do
150
+ LegacyFacter.add(env_name, fact_type: :external, is_env: true) do
147
151
  has_weight 1_000_000
148
152
  setcode { value }
149
153
  end
@@ -137,11 +137,17 @@ module LegacyFacter
137
137
  if LegacyFacter.json?
138
138
  JSON.parse(content)
139
139
  else
140
- LegacyFacter.warnonce "Cannot parse JSON data file #{filename} without the json library."
141
- LegacyFacter.warnonce 'Suggested next step is `gem install json` to install the json library.'
140
+ log.warnonce "Cannot parse JSON data file #{filename} without the json library."
141
+ log.warnonce 'Suggested next step is `gem install json` to install the json library.'
142
142
  nil
143
143
  end
144
144
  end
145
+
146
+ private
147
+
148
+ def log
149
+ @log ||= Facter::Log.new(self)
150
+ end
145
151
  end
146
152
 
147
153
  register(JsonParser) do |filename|