- name: "Initialization variables"
path: "/root/puppet_variables.json"
+ - name: "Puppet ldap variables"
+ data_hash: ldap_data
+
- name: "Per-role environment data"
mapped_paths: [ldapvar.self.vars.roles, role, "roles/%{role}.yaml"]
--- /dev/null
+require 'json'
+
+Puppet::Functions.create_function(:ldap_data) do
+ dispatch :ldap_data do
+ param 'Hash', :options
+ param 'Puppet::LookupContext', :context
+ end
+
+ def ldap_data(options, context)
+ begin
+ require 'ldap'
+ require 'puppet/util/ldap/connection'
+ rescue
+ context.not_found
+ return
+ end
+
+ if !context.cache_has_key("ldap_lookup")
+ begin
+ conn = Puppet::Util::Ldap::Connection.instance
+ conn.start
+ connection = conn.connection
+ rescue ::LDAP::ResultError => e
+ raise Puppet::ParseError, ("ldapquery(): LDAP ResultError - #{e.message}")
+ end
+
+ host = Facter.value('ec2_metadata')["hostname"]
+ base = Puppet[:ldapbase]
+ scope = ::LDAP::LDAP_SCOPE_SUBTREE
+ filter = "(objectclass=*)"
+
+ data = {}
+ connection.search(base, scope, filter) do |entry|
+ data_ = entry.to_hash
+ jsons = data_["immaePuppetJson"] || []
+ jsons.each do |json|
+ data.merge!(JSON.parse(json))
+ end
+ end
+
+ context.cache("ldap_lookup", data)
+ end
+
+ context.cached_value("ldap_lookup")
+ end
+end