File: ruby.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 (40 lines) | stat: -rw-r--r-- 1,227 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
# frozen_string_literal: true

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

require 'puppet/provider/elastic_rest'

require 'puppet_x/elastic/deep_to_i'
require 'puppet_x/elastic/deep_to_s'

Puppet::Type.type(:elasticsearch_component_template).provide(
  :ruby,
  parent: Puppet::Provider::ElasticREST,
  api_uri: '_component_template',
  metadata: :content,
  metadata_pipeline: [
    lambda { |data|
      # As api returns values keyed under component_template
      data.merge!(data['component_template']) if data['component_template'].is_a? Hash
      data.delete('component_template')
    },
    ->(data) { Puppet_X::Elastic.deep_to_s data },
    ->(data) { Puppet_X::Elastic.deep_to_i data }
  ]
) do
  desc 'A REST API based provider to manage Elasticsearch component templates.'

  mk_resource_methods

  # We need to override parent since actual data comes as array under component_templates key
  def self.process_body(body)
    JSON.parse(body).fetch('component_templates', []).map do |item|
      {
        :name => item['name'],
        :ensure => :present,
        metadata => process_metadata(item.keep_if { |key| key != 'name' }),
        :provider => name
      }
    end
  end
end