X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=3rdparty%2Fmodules%2Fstdlib%2Flib%2Ffacter%2Ffacter_dot_d.rb;h=2d6e179616e8a933693b50ce16c6e6bc494984d9;hb=30caaa85aed7015ca0d77216bff175eebd917eb7;hp=5c5fb1fded10a283ef0b0df99906ef96bb5e97a0;hpb=6963202b4b62c2816655ac9532521b018fdf83bd;p=mirror%2Fdsa-puppet.git diff --git a/3rdparty/modules/stdlib/lib/facter/facter_dot_d.rb b/3rdparty/modules/stdlib/lib/facter/facter_dot_d.rb index 5c5fb1fde..2d6e17961 100644 --- a/3rdparty/modules/stdlib/lib/facter/facter_dot_d.rb +++ b/3rdparty/modules/stdlib/lib/facter/facter_dot_d.rb @@ -1,5 +1,6 @@ -# A Facter plugin that loads facts from /etc/facter/facts.d -# and /etc/puppetlabs/facter/facts.d. +# @summary +# A Facter plugin that loads facts from /etc/facter/facts.d +# and /etc/puppetlabs/facter/facts.d. # # Facts can be in the form of JSON, YAML or Text files # and any executable that returns key=value pairs. @@ -11,23 +12,25 @@ # The cache is stored in $libdir/facts_dot_d.cache as a mode # 600 file and will have the end result of not calling your # fact scripts more often than is needed - class Facter::Util::DotD require 'yaml' - - def initialize(dir="/etc/facts.d", cache_file=File.join(Puppet[:libdir], "facts_dot_d.cache")) + # These will be nil if Puppet is not available. + def initialize(dir = '/etc/facts.d', cache_file = File.join(Puppet[:libdir], 'facts_dot_d.cache')) @dir = dir @cache_file = cache_file @cache = nil - @types = {".txt" => :txt, ".json" => :json, ".yaml" => :yaml} + @types = { '.txt' => :txt, '.json' => :json, '.yaml' => :yaml } end + # entries def entries - Dir.entries(@dir).reject { |f| f =~ /^\.|\.ttl$/ }.sort.map { |f| File.join(@dir, f) } + Dir.entries(@dir).reject { |f| f =~ %r{^\.|\.ttl$} }.sort.map { |f| File.join(@dir, f) } rescue [] end + # fact_type + # @param file def fact_type(file) extension = File.extname(file) @@ -35,23 +38,27 @@ class Facter::Util::DotD type = :script if type == :unknown && File.executable?(file) - return type + type end + # txt_parser + # @param file def txt_parser(file) File.readlines(file).each do |line| - if line =~ /^([^=]+)=(.+)$/ - var = $1; val = $2 + next unless line =~ %r{^([^=]+)=(.+)$} + var = Regexp.last_match(1) + val = Regexp.last_match(2) - Facter.add(var) do - setcode { val } - end + Facter.add(var) do + setcode { val } end end rescue StandardError => e Facter.warn("Failed to handle #{file} as text facts: #{e.class}: #{e}") end + # json_parser + # @param file def json_parser(file) begin require 'json' @@ -60,7 +67,7 @@ class Facter::Util::DotD raise end - JSON.load(File.read(file)).each_pair do |f, v| + JSON.parse(File.read(file)).each_pair do |f, v| Facter.add(f) do setcode { v } end @@ -69,6 +76,8 @@ class Facter::Util::DotD Facter.warn("Failed to handle #{file} as json facts: #{e.class}: #{e}") end + # yaml_parser + # @param file def yaml_parser(file) require 'yaml' @@ -81,11 +90,15 @@ class Facter::Util::DotD Facter.warn("Failed to handle #{file} as yaml facts: #{e.class}: #{e}") end + # script_parser + # @param file def script_parser(file) result = cache_lookup(file) ttl = cache_time(file) - unless result + if result + Facter.debug("Using cached data for #{file}") + else result = Facter::Util::Resolution.exec(file) if ttl > 0 @@ -93,17 +106,15 @@ class Facter::Util::DotD cache_store(file, result) cache_save! end - else - Facter.debug("Using cached data for #{file}") end result.split("\n").each do |line| - if line =~ /^(.+)=(.+)$/ - var = $1; val = $2 + next unless line =~ %r{^(.+)=(.+)$} + var = Regexp.last_match(1) + val = Regexp.last_match(2) - Facter.add(var) do - setcode { val } - end + Facter.add(var) do + setcode { val } end end rescue StandardError => e @@ -111,19 +122,24 @@ class Facter::Util::DotD Facter.debug(e.backtrace.join("\n\t")) end + # cache_save def cache_save! cache = load_cache - File.open(@cache_file, "w", 0600) { |f| f.write(YAML.dump(cache)) } - rescue + File.open(@cache_file, 'w', 0o600) { |f| f.write(YAML.dump(cache)) } + rescue # rubocop:disable Lint/HandleExceptions end + # cache_store + # @param file def cache_store(file, data) load_cache - @cache[file] = {:data => data, :stored => Time.now.to_i} - rescue + @cache[file] = { :data => data, :stored => Time.now.to_i } + rescue # rubocop:disable Lint/HandleExceptions end + # cache_lookup + # @param file def cache_lookup(file) cache = load_cache @@ -131,35 +147,33 @@ class Facter::Util::DotD ttl = cache_time(file) - if cache[file] - now = Time.now.to_i + return nil unless cache[file] + now = Time.now.to_i - return cache[file][:data] if ttl == -1 - return cache[file][:data] if (now - cache[file][:stored]) <= ttl - return nil - else - return nil - end + return cache[file][:data] if ttl == -1 + return cache[file][:data] if (now - cache[file][:stored]) <= ttl + return nil rescue return nil end + # cache_time + # @param file def cache_time(file) - meta = file + ".ttl" + meta = file + '.ttl' return File.read(meta).chomp.to_i rescue return 0 end + # load_cache def load_cache - unless @cache - if File.exist?(@cache_file) - @cache = YAML.load_file(@cache_file) - else - @cache = {} - end - end + @cache ||= if File.exist?(@cache_file) + YAML.load_file(@cache_file) + else + {} + end return @cache rescue @@ -167,33 +181,32 @@ class Facter::Util::DotD return @cache end + # create def create entries.each do |fact| type = fact_type(fact) parser = "#{type}_parser" - if respond_to?("#{type}_parser") - Facter.debug("Parsing #{fact} using #{parser}") + next unless respond_to?("#{type}_parser") + Facter.debug("Parsing #{fact} using #{parser}") - send(parser, fact) - end + send(parser, fact) end end end - -mdata = Facter.version.match(/(\d+)\.(\d+)\.(\d+)/) +mdata = Facter.version.match(%r{(\d+)\.(\d+)\.(\d+)}) if mdata - (major, minor, patch) = mdata.captures.map { |v| v.to_i } + (major, minor, _patch) = mdata.captures.map { |v| v.to_i } if major < 2 # Facter 1.7 introduced external facts support directly - unless major == 1 and minor > 6 - Facter::Util::DotD.new("/etc/facter/facts.d").create - Facter::Util::DotD.new("/etc/puppetlabs/facter/facts.d").create + unless major == 1 && minor > 6 + Facter::Util::DotD.new('/etc/facter/facts.d').create + Facter::Util::DotD.new('/etc/puppetlabs/facter/facts.d').create # Windows has a different configuration directory that defaults to a vendor # specific sub directory of the %COMMON_APPDATA% directory. - if Dir.const_defined? 'COMMON_APPDATA' then + if Dir.const_defined? 'COMMON_APPDATA' # rubocop:disable Metrics/BlockNesting : Any attempt to alter this breaks it windows_facts_dot_d = File.join(Dir::COMMON_APPDATA, 'PuppetLabs', 'facter', 'facts.d') Facter::Util::DotD.new(windows_facts_dot_d).create end