--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/components/ruby/puppet/files/solaris/lib/puppet/provider/ldap/solaris.rb Fri Nov 07 12:43:50 2014 -0800
@@ -0,0 +1,121 @@
+#
+# 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, 2014, 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'
+
+ 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).each_line.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
+ begin
+ props[:bind_passwd] = svcprop("-p", "cred/bind_passwd",
+ "svc:/network/ldap/client").strip
+ rescue
+ end
+
+ 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 }
+
+ # in Solaris 11, the list of values needs to be single
+ # argument to svccfg.
+ values = ""
+ for entry in should
+ values += "\"#{entry}\" "
+ end
+ values = "(" + values + ")"
+ svccfg("-s", Ldap_fmri, "setprop",
+ pg + "/" + field.to_s, "=", values)
+ else
+ # Puppet seems to get confused about when to pass an empty
+ # string or "\"\"". Catch either condition to handle
+ # passing values to SMF correctly
+ if should.to_s.empty? or should.to_s == '""'
+ value = should.to_s
+ else
+ value = "\"" + should.to_s + "\""
+ end
+ svccfg("-s", Ldap_fmri, "setprop",
+ pg + "/" + field.to_s, "=", value)
+ 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