17284016 nis, ldap, and dns refreshed on every Puppet run
17277145 nsswitch provider object error and missing parameter
17271383 NIS provider is not updating domainname property
17270555 NIS provider returns an error when attempting to set securenets parameter
#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# or http://www.opensolaris.org/os/licensing.
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#
#
# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
#
Puppet::Type.type(:ldap).provide(:ldap) do
desc "Provider for management of the LDAP client for Oracle Solaris"
confine :operatingsystem => [:solaris]
defaultfor :osfamily => :solaris, :kernelrelease => ['5.11', '5.12']
commands :svccfg => '/usr/sbin/svccfg', :svcprop => '/usr/bin/svcprop'
class << self; attr_accessor :ldap_fmri end
@@ldap_fmri = "svc:/network/ldap/client"
def initialize(resource)
super
@refresh_needed = false
end
def self.instances
if Process.euid != 0
return []
end
props = {}
validprops = Puppet::Type.type(:ldap).validproperties
svcprop("-p", "config", @@ldap_fmri).split("\n").collect do |line|
data = line.split()
fullprop = data[0]
type = data[1]
if data.length > 2
value = data[2..-1].join(" ")
else
value = nil
end
pg, prop = fullprop.split("/")
props[prop] = value if validprops.include? prop.to_sym
end
props[:bind_passwd] = svcprop("-p", "cred/bind_passwd",
"svc:/network/ldap/client").strip
props[:name] = "current"
return Array new(props)
end
Puppet::Type.type(:ldap).validproperties.each do |field|
# get the property group
pg = Puppet::Type.type(:ldap).propertybyname(field).pg
define_method(field) do
begin
svcprop("-p", pg + "/" + field.to_s, @@ldap_fmri).strip()
rescue
# if the property isn't set, don't raise an error
nil
end
end
define_method(field.to_s + "=") do |should|
begin
if should.is_a? Array
should.collect! { |value| value.to_s }
# the first entry needs the open paren and the last entry
# needs the close paren
should[0] = "(" + should[0]
should[-1] = should[-1] + ")"
svccfg("-s", @@ldap_fmri, "setprop",
pg + "/" + field.to_s, "=", should)
else
svccfg("-s", @@ldap_fmri, "setprop",
pg + "/" + field.to_s, "=", should.to_s)
end
@refresh_needed = true
rescue => detail
raise Puppet::Error,
"Unable to set #{field.to_s} to #{should.inspect}\n"
"#{detail}\n"
end
end
end
def flush
if @refresh_needed == true
svccfg("-s", @@ldap_fmri, "refresh")
end
end
end