#!/usr/bin/ruby -W0

base = File.expand_path(File.join(File.dirname(__FILE__), ".."))
$LOAD_PATH << File.join(base, "lib")
$LOAD_PATH << File.join(base, "examples")

require 'active_ldap'
require 'objects/user'
require 'objects/group'

argv, opts, options = ActiveLdap::Command.parse_options do |opts, options|
  opts.banner += " USER_NAME CN UID"
end

if argv.size == 3
  name, cn, uid = argv
else
  $stderr.puts opts
  exit 1
end

pwb = Proc.new do |user|
  ActiveLdap::Command.read_password("[#{user}] Password: ")
end

ActiveLdap::Base.establish_connection(:password_block => pwb,
                                      :allow_anonymous => false)

unless User.exists?(name)
  $stderr.puts("User #{name} doesn't exist.")
  exit 1
end

100.times do |i|
  user = User.find(name)
  user.cn = cn
  user.uid_number = uid
  user.gid_number = uid

  user.add_class('strongAuthenticationUser')
  cert_file = File.join(File.dirname(__FILE__), 'example.der')
  user.user_certificate = File.read(cert_file)

  unless user.save
    puts "failed #{i}"
    puts user.errors.full_messages
    exit 1
  end

  # puts "success [#{i}]"
end
