module ActiveLdap::Populate

def ensure_base(base_class=nil, options={})

def ensure_base(base_class=nil, options={})
  base_class ||= Base
  return unless base_class.search(:scope => :base).empty?
  dc_base_class = options[:dc_base_class] || base_class
  ou_base_class = options[:ou_base_class] || base_class
  base_dn = DN.parse(base_class.base)
  suffixes = []
  base_dn.rdns.reverse_each do |rdn|
    name, value = rdn.to_a[0]
    prefix = suffixes.join(",")
    suffixes.unshift("#{name}=#{value}")
    begin
      case name.downcase
      when "dc"
        ensure_dc(value, prefix, dc_base_class)
      when "ou"
        ensure_ou(value,
                  :base => prefix,
                  :base_class => ou_base_class)
      end
    rescue ActiveLdap::OperationNotPermitted
    end
  end
end

def ensure_dc(name, prefix, base_class=nil)

def ensure_dc(name, prefix, base_class=nil)
  base_class ||= Base
  name = name.to_s if name.is_a?(DN)
  name = name.gsub(/\Adc\s*=\s*/i, '')
  dc_class = Class.new(base_class)
  dc_class.ldap_mapping(:dn_attribute => "dc",
                        :prefix => "",
                        :scope => :base,
                        :classes => ["top", "dcObject", "organization"])
  dc_class.base = prefix
  return if dc_class.exist?(name)
  dc = dc_class.new(name)
  dc.o = dc.dc
  dc.save!
end

def ensure_ou(name, options={})

def ensure_ou(name, options={})
  if options.is_a?(Class)
    base_class = options
    options = {}
  else
    base_class = options[:base_class] || Base
  end
  name = name.to_s if name.is_a?(DN)
  name = name.gsub(/\Aou\s*=\s*/i, '')
  ou_class = Class.new(base_class)
  ou_class.ldap_mapping(:dn_attribute => "ou",
                        :prefix => "",
                        :classes => ["top", "organizationalUnit"])
  ou_class.base = options[:base]
  return if ou_class.exist?(name)
  ou_class.new(name).save!
end