--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/components/ruby/puppet/files/solaris/lib/puppet/provider/ldap/solaris.rb Fri Sep 12 10:57:15 2014 -0600
@@ -0,0 +1,122 @@
+#
+# 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).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
+
+ # attempt to set the cred/bind_passwd value
+ begin
+ props[:bind_passwd] = svcprop("-p", "cred/bind_passwd",
+ "svc:/network/ldap/client").strip()
+ rescue
+ props[:bind_passwd] = nil
+ 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 }
+
+ # 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
+ # 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