File: elastic_yaml.rb

package info (click to toggle)
puppet-module-voxpupuli-elasticsearch 9.0.0-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,496 kB
  • sloc: ruby: 9,906; sh: 392; makefile: 4
file content (61 lines) | stat: -rw-r--r-- 1,661 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# frozen_string_literal: true

$LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', '..'))

require 'puppet/provider/elastic_parsedfile'
require 'puppet/util/package'
require 'puppet_x/elastic/hash'

# Provider for yaml-based Elasticsearch configuration files.
class Puppet::Provider::ElasticYaml < Puppet::Provider::ElasticParsedFile
  class << self
    attr_accessor :metadata
  end

  # Transform a given string into a Hash-based representation of the
  # provider.
  def self.parse(text)
    yaml = YAML.safe_load text
    if yaml
      yaml.map do |key, metadata|
        {
          :name => key,
          :ensure => :present,
          @metadata => metadata
        }
      end
    else
      []
    end
  end

  # Transform a given list of provider records into yaml-based
  # representation.
  def self.to_file(records)
    yaml = records.map do |record|
      # Convert top-level symbols to strings
      record.transform_keys(&:to_s)
    end
    yaml = yaml.reduce({}) do |hash, record|
      # Flatten array of hashes into single hash
      hash.merge(record['name'] => record.delete(@metadata.to_s))
    end
    yaml = yaml.extend(Puppet_X::Elastic::SortedHash).to_yaml.split("\n")

    yaml.shift if yaml.first =~ %r{---}
    yaml = yaml.join("\n")

    yaml << "\n"
  end

  def self.skip_record?(_record)
    false
  end

  # This is ugly, but it's overridden in ParsedFile with abstract
  # functionality we don't need for our simple provider class.
  # This has been observed to break in Puppet version 3/4 switches.
  def self.valid_attr?(klass, attr_name)
    klass.is_a? Class ? klass.parameters.include?(attr_name) : true
  end
end